问题:将一个数组中的数据利用冒泡排序法进行升序排序
思路:确定趟数,需要n-1趟,然后对每一趟内部进行两两比较,需要比较n-1-i趟。
cpp
#include <stdio.h>
//冒泡排序
int bubble_sort(int arr[], int sz)
{
int i = 0;
//确定趟数
for (i = 0; i < sz - 1; i++)
{
int j = 0;
//每一趟内部两两排序
for (j = 0; j < sz - 1 - i; j++)
{
if (arr[j] > arr[j + 1])
{
int tmp = 0;
tmp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = tmp;
}
}
}
}
//打印输出
int print_sort(int arr[], int sz)
{
int i = 0;
for (i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
}
int main()
{
int arr[] = { 9,3,2,5,6,0,1,4,7,8 };
int sz = sizeof(arr) / sizeof(arr[0]);
bubble_sort(arr, sz);
print_sort(arr, sz);
return 0;
}
程序结果: