数组arr=[4,6,1,8,3,2,1],按从小到大排序此数组?

数组arr=[4,6,1,8,3,2,1],按从小到大排序此数组?

arr=[4,6,1,8,3,2,1]
arr.sort()
print(arr)

img

  • 帮你找了个相似的问题, 你可以看下: https://ask.csdn.net/questions/7606029
  • 除此之外, 这篇博客: 将 arr[]={9,8,7,6,5,4,3,2,1,0} 用冒泡排序的方法排序成{0,1,2,3,4,5,6,7,8,9}中的 冒泡排序重新排序数组 部分也许能够解决你的问题, 你可以仔细阅读以下内容或跳转源博客中阅读:
  • #include <stdio.h>
    #include <stdlib.h>
    void bubble_sort(int arr[], int sz)
    {
    	//确定冒泡排序函数
    	int i = 0;
    	for (i = 0; i < sz - 1; i++)
    	{
    		int falg = 1;//假设这一趟要排序的数据已经有序
    		//每一趟冒泡排序函数
    		int j = 0;
    		for (j = 0; j <sz - 1 - i; j++)
    		{
    			if (arr[j]>arr[j + 1])
    			{
    				int tmp = arr[j];
    				arr[j] = arr[j + 1];
    				arr[j + 1] = tmp;
    				falg = 0;//本趟排序不完全有序
    }
    	}
    
    		if (falg == 1)
    		{
    			break;
    		}
       	}
    }
    int main()
    {
    	int arr[] = { 9, 8, 7, 6, 5, 4, 3, 2, 1,0 };
    	int i = 0;
    	int sz = sizeof(arr) / sizeof(arr[0]);
    	//对arr进行排序,排成升序
    	//arr是数组,我们对数组arr进行传参,实际上传递过去的是数组arr首元素的地址 arr[0]
    	bubble_sort(arr, sz);//冒泡排序函数
    	for (i = 0; i < sz; i++)
    	{
    		printf("%d ", arr[i]);
    	}
    	system("pause");
    	return 0;
    }
    

    在这里插入图片描述
    这样就讲原先数组中的数用冒泡排序的方法重新排序完成了。

  • 以下回答由chatgpt基于相关博客总结生成:

    解决方案:

    要对数组arr进行排序,可以使用冒泡排序算法进行实现。

    首先,创建一个bubble_sort()函数来实现冒泡排序。函数需要传入数组arr及其长度sz作为参数。

    冒泡排序的思路是通过多次比较相邻的元素,并根据需要交换位置来达到排序的目的。具体步骤如下:

    1. 在bubble_sort()函数中,使用两个嵌套的for循环,外层循环控制需要比较的轮数,内层循环控制每一轮比较的次数。

    2. 在内层循环中,判断arr[j]是否大于arr[j+1],如果是,则交换两个元素的位置。

    3. 在每一轮比较完毕后,如果没有发生交换,则说明数组已经有序,可以直接退出循环。

    4. 在bubble_sort()函数结束后,可以在main()函数中调用该函数,并将需要排序的数组arr和其长度sz传入。

    5. 最后,使用for循环输出排序后的数组。

    下面是完整的示例代码:

    #include <stdio.h>
    
    void bubble_sort(int arr[], int sz)
    {
        int i, j;
        for (i = 0; i < sz - 1; i++)
        {   
            int flag = 1; // 假设这一趟要排序的数据已经有序
            for (j = 0; j < sz - 1 - i; j++)
            {
                if (arr[j] > arr[j + 1])
                {
                    int tmp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = tmp;
                    flag = 0; // 本趟排序不完全有序
                }
            }
            if (flag == 1)
                break;
        }
    }
    
    int main()
    {
        int arr[] = {4, 6, 1, 8, 3, 2, 1};
        int sz = sizeof(arr) / sizeof(arr[0]);
    
        bubble_sort(arr, sz);
    
        int i;
        for (i = 0; i < sz; i++)
        {
            printf("%d ", arr[i]);
        }
    
        return 0;
    }
    

    以上代码使用了C语言来实现对数组arr的冒泡排序,输出的结果是按照从小到大排序后的数组元素。可以将以上代码保存为一个.c文件,然后使用C编译器进行编译运行即可。