冒泡排序算法c语言代码
以下是冒泡排序算法的C语言代码:
#include <stdio.h>
void bubbleSort(int arr[], int n) {
for (int i = 0; i < n-1; i++) {
for (int j = 0; j < n-i-1; j++) {
if (arr[j] > arr[j+1]) {
// 交换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
函数,该函数接受一个整型数组和数组的长度作为参数。在函数内部使用两个嵌套的循环来比较相邻的元素,并根据需要交换它们的位置。外层循环控制比较的轮数,内层循环控制每一轮比较的次数。在每一轮比较中,如果前一个元素大于后一个元素,则交换它们的位置。最后,在main
函数中定义了一个整型数组,并调用bubbleSort
函数对数组进行排序。最后,使用printf
函数打印排序后的数组。
冒泡排序是一种简单但效率较低的排序算法。它的基本思想是通过相邻元素的比较和交换,将较大的元素逐渐“冒泡”到数组的末尾。
冒泡排序的时间复杂度为O(n^2),其中n是数组的长度。在最坏情况下,即数组完全逆序的情况下,冒泡排序需要进行n*(n-1)/2次比较和交换操作。
冒泡排序的优化方法有两种:
设置一个标志位,如果某一轮比较中没有发生交换,说明数组已经有序,可以提前结束排序。
记录每一轮最后一次交换的位置,下一轮比较只需要进行到该位置即可,因为该位置之后的元素已经有序。
冒泡排序的特点是稳定性好,即相等元素的相对位置不会发生改变。但是由于每一轮只能将一个元素放到最终位置,所以效率较低,不适用于大规模数据的排序。
希望以上补充的信息对您有帮助!