C语言排序算法详解及应用:从冒泡排序到快速排序173


C语言作为一门底层编程语言,其高效性和灵活性使其在系统编程和算法实现中占据重要地位。排序算法是计算机科学中的一个核心问题,而C语言提供了丰富的工具和手段来实现各种高效的排序算法。本文将深入探讨几种常见的C语言排序算法,包括其原理、代码实现以及性能分析,并结合实际应用场景,帮助读者更好地理解和运用这些算法。

一、冒泡排序 (Bubble Sort)

冒泡排序是最简单易懂的排序算法之一。其基本思想是重复地遍历待排序的列表,比较相邻的两个元素,如果它们的顺序错误,就交换它们。每一次遍历都会将最大的(或最小的)元素“冒泡”到列表的末尾。尽管简单,但冒泡排序的效率非常低,时间复杂度为O(n²),不适用于大型数据集。
#include
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("排序后的数组: ");
for (int i = 0; i < n; i++)
printf("%d ", arr[i]);
printf("");
return 0;
}

二、选择排序 (Selection Sort)

选择排序也是一种简单的排序算法。它重复地找到未排序元素中的最小元素,并将其放置到已排序序列的末尾。时间复杂度同样是O(n²),但与冒泡排序相比,选择排序的交换次数更少,在某些情况下可能略微高效。
#include
void selectionSort(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;
// 交换 arr[min_idx] 和 arr[i]
int temp = arr[min_idx];
arr[min_idx] = arr[i];
arr[i] = temp;
}
}
int main() {
// ... (与冒泡排序的main函数类似)
}

三、插入排序 (Insertion Sort)

插入排序的工作原理类似于我们整理扑克牌的方式。它逐个处理数组中的元素,将每个元素插入到已排序部分的正确位置。平均时间复杂度为O(n²),但对于部分有序的数据,其效率会显著提高,甚至可以达到O(n)。
#include
void insertionSort(int arr[], int n) {
int i, key, j;
for (i = 1; i < n; i++) {
key = arr[i];
j = i - 1;
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j = j - 1;
}
arr[j + 1] = key;
}
}
int main() {
// ... (与冒泡排序的main函数类似)
}

四、快速排序 (Quick Sort)

快速排序是一种基于分治策略的高效排序算法。它选择一个元素作为“枢轴”,将数组划分成两部分:小于枢轴的元素和大于枢轴的元素。然后递归地对这两部分进行排序。快速排序的平均时间复杂度为O(n log n),在实际应用中表现出色,但最坏情况下时间复杂度为O(n²)。
#include
void quickSort(int arr[], int low, int high) {
if (low < high) {
int pi = partition(arr, low, high);
quickSort(arr, low, pi - 1);
quickSort(arr, pi + 1, high);
}
}
int partition(int arr[], int low, int high) {
int pivot = arr[high];
int i = (low - 1);
for (int j = low; j

2025-04-22


上一篇:C语言输出固定字符:方法详解及进阶技巧

下一篇:C语言高效实现质数筛选与循环输出