冒泡排序是一种简单的排序方法,一般用于对数组中的元素进行升序或降序的排序。
在一个数组中,从第一个元素开始,依次和之后的元素进行比较,每次比较让较大的元素交换到右边,较小的元素交换到左边,直到本轮比较全部完成后,最大的数就会排到最右边,则最终所有元素会按照从小到大的顺序排好序,即冒泡排序。
冒泡排序的核心思想:两个相邻的元素进行比较。
以升序为例,代码如下:
#include<stdio.h>
void 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 n = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = n;
}
}
}
}
int main()
{
int arr[] = { 5,3,6,7,9,1,2,8,4,0 };
int sz = sizeof(arr) / sizeof(arr[0]);
bubble_sort(arr, sz);//使用冒泡排序对数组进行升序
int i = 0;
for (i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
代码比较简单,仅供参考。