c语言编程笔录

首页 >   > 笔记大全

笔记大全

c语言冒号排序

更新时间:2024-01-24

前言

冒泡排序是一种简单但效率较低的排序算法,可以用于对数组进行升序排列。该算法通过比较相邻元素并交换顺序,直到整个数组有序为止。

代码实现

下面是使用C语言实现冒泡排序的代码:

#include 

void 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),在数据量较大时效率较低。然而,它仍可用于小型数据集的排序。