数组arr=[4,6,1,8,3,2,1],按从小到大排序此数组?
arr=[4,6,1,8,3,2,1]
arr.sort()
print(arr)
#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;
}
这样就讲原先数组中的数用冒泡排序的方法重新排序完成了。
解决方案:
要对数组arr进行排序,可以使用冒泡排序算法进行实现。
首先,创建一个bubble_sort()函数来实现冒泡排序。函数需要传入数组arr及其长度sz作为参数。
冒泡排序的思路是通过多次比较相邻的元素,并根据需要交换位置来达到排序的目的。具体步骤如下:
在bubble_sort()函数中,使用两个嵌套的for循环,外层循环控制需要比较的轮数,内层循环控制每一轮比较的次数。
在内层循环中,判断arr[j]是否大于arr[j+1],如果是,则交换两个元素的位置。
在每一轮比较完毕后,如果没有发生交换,则说明数组已经有序,可以直接退出循环。
在bubble_sort()函数结束后,可以在main()函数中调用该函数,并将需要排序的数组arr和其长度sz传入。
最后,使用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编译器进行编译运行即可。