c语言冒号排序
更新时间:2024-01-24前言
冒泡排序是一种简单但效率较低的排序算法,可以用于对数组进行升序排列。该算法通过比较相邻元素并交换顺序,直到整个数组有序为止。
代码实现
下面是使用C语言实现冒泡排序的代码:
#includevoid bubbleSort(int arr[], int n) { int i, j; for (i = 0; i < n-1; i++) { for (j = 0; j < n-i-1; j++) { if (arr[j] > arr[j+1]) { int temp = arr[j]; arr[j] = arr[j+1]; arr[j+1] = temp; } } } } int main() { int arr[] = {64, 34, 25, 12, 22, 11, 90}; int n = sizeof(arr)/sizeof(arr[0]); bubbleSort(arr, n); printf("排序后的数组:\n"); for (int i = 0; i < n; i++) { printf("%d ", arr[i]); } return 0; }
代码解释
上述代码中,我们定义了一个函数bubbleSort,它接受一个整型数组和数组的大小作为参数。
外层循环for (i = 0; i < n-1; i++)用于控制排序的轮数,每轮将会将当前最大的数移到最右端。
内层循环for (j = 0; j < n-i-1; j++)用于比较相邻元素的大小,并进行交换。
交换操作通过使用一个临时变量temp来完成。
最后,在主函数中定义了一个待排序的数组,调用bubbleSort函数进行排序,并输出排序后的数组。
总结
冒泡排序是一种基础的排序算法,其实现较为简单。该算法的时间复杂度为O(n^2),在数据量较大时效率较低。然而,它仍可用于小型数据集的排序。