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语言高效实现质数筛选与循环输出
PHP高效解析JSON字符串数组:从入门到精通与实战优化
https://www.shuihudhg.cn/134427.html
Java数据读取循环:核心原理、实战技巧与性能优化全解析
https://www.shuihudhg.cn/134426.html
PHP 文件包含深度解析:从基础用法到安全实践与现代应用
https://www.shuihudhg.cn/134425.html
Python编程考试全攻略:代码实现技巧、高频考点与实战演练
https://www.shuihudhg.cn/134424.html
PHP日期时间处理:多种方法去除时间字符串中的秒级精度
https://www.shuihudhg.cn/134423.html
热门文章
C 语言中实现正序输出
https://www.shuihudhg.cn/2788.html
c语言选择排序算法详解
https://www.shuihudhg.cn/45804.html
C 语言函数:定义与声明
https://www.shuihudhg.cn/5703.html
C语言中的开方函数:sqrt()
https://www.shuihudhg.cn/347.html
C 语言中字符串输出的全面指南
https://www.shuihudhg.cn/4366.html