📜  选择排序 - C 编程语言(1)

📅  最后修改于: 2023-12-03 15:41:57.402000             🧑  作者: Mango

选择排序 - C 编程语言

选择排序是一种简单的排序算法,它的工作原理如下:

  1. 在未排序的序列中找到最小(大)元素,存放到排序序列的起始位置。
  2. 从剩余未排序元素中继续寻找最小(大)元素,放到已排序序列的末尾。
  3. 重复步骤 2,直到所有元素均排序完毕。
C 代码实现

以下是使用 C 语言实现选择排序的代码:

#include <stdio.h>

void selection_sort(int arr[], int n) {
    int i, j, min_idx;
    for (i = 0; i < n-1; i++) {
        min_idx = i;
        for (j = i+1; j < n; j++) {
            if (arr[j] < arr[min_idx]) {
                min_idx = j;
            }
        }
        // Swap the found minimum element with the first element
        int temp = arr[min_idx];
        arr[min_idx] = arr[i];
        arr[i] = temp;
    }
}

int main() {
    int arr[] = {64, 25, 12, 22, 11};
    int n = sizeof(arr)/sizeof(arr[0]);
    selection_sort(arr, n);
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
    return 0;
}
代码分析

选择排序由两层循环构成,外层循环控制选择的元素个数,从第一个元素开始,一直到倒数第二个元素,内层循环则寻找未排序部分中的最小元素,并记录其索引值。一旦内层循环结束,就交换选定的元素与最小元素的位置。时间复杂度为 O(n^2)。

总结

选择排序虽然时间复杂度较高,但是非常简单易懂,对于一些较小的数据集还是很实用的。使用时需要注意元素的数据类型和数组长度等细节。