C语言实现三种排序算法:冒泡排序、选择排序、插入排序
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语言中实现,并可以用于对数据进行排序。理解这些算法的原理和实现方式有助于开发者选择合适的排序算法,以提高程序效率。
原文地址: https://www.cveoy.top/t/topic/lW8Z 著作权归作者所有。请勿转载和采集!