冒泡排序算法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次比较和交换操作。

冒泡排序的优化方法有两种:

设置一个标志位,如果某一轮比较中没有发生交换,说明数组已经有序,可以提前结束排序。

记录每一轮最后一次交换的位置,下一轮比较只需要进行到该位置即可,因为该位置之后的元素已经有序。

冒泡排序的特点是稳定性好,即相等元素的相对位置不会发生改变。但是由于每一轮只能将一个元素放到最终位置,所以效率较低,不适用于大规模数据的排序。

希望以上补充的信息对您有帮助!