C语言实现三种排序算法:冒泡排序、选择排序、插入排序

本文将使用C语言代码演示三种常见的排序算法:冒泡排序、选择排序和插入排序。通过代码示例,详细讲解了每种排序算法的原理和实现过程,并附带了清晰的注释。

1. 冒泡排序

冒泡排序是一种简单的排序算法,它重复地遍历要排序的列表,比较相邻的元素,并交换它们的位置,以便较大的元素“冒泡”到列表的末尾。

void bubble_sort(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;
            }
        }
    }
}

2. 选择排序

选择排序算法首先找到列表中最小的元素,将其放置在列表的第一个位置。然后,找到剩余元素中最小的元素,将其放置在第二个位置,以此类推。

void selection_sort(int arr[], int n) {
    int i, j, min_index;
    for (i = 0; i < n - 1; i++) {
        min_index = i;
        for (j = i + 1; j < n; j++) {
            if (arr[j] < arr[min_index]) {
                min_index = j;
            }
        }
        int temp = arr[i];
        arr[i] = arr[min_index];
        arr[min_index] = temp;
    }
}

3. 插入排序

插入排序算法将列表分为两个子列表:已排序子列表和未排序子列表。算法从未排序子列表中取出第一个元素,将其插入到已排序子列表的适当位置,以保持已排序子列表的有序性。

void insertion_sort(int arr[], int n) {
    int i, j, key;
    for (i = 1; i < n; i++) {
        key = arr[i];
        j = i - 1;
        while (j >= 0 && arr[j] > key) {
            arr[j + 1] = arr[j];
            j--;
        }
        arr[j + 1] = key;
    }
}

总结

本文介绍了三种基本的排序算法:冒泡排序、选择排序和插入排序。这些算法都可以在C语言中实现,并可以用于对数据进行排序。理解这些算法的原理和实现方式有助于开发者选择合适的排序算法,以提高程序效率。

C语言实现三种排序算法:冒泡排序、选择排序、插入排序

原文地址: https://www.cveoy.top/t/topic/lW8Z 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录