C语言实现冒泡排序和选择排序算法
冒泡排序和选择排序是两种比较简单的排序算法,下面分别给出它们的C语言实现。
冒泡排序:
void bubble_sort(int arr[], int len) {
int i, j, temp;
for (i = 0; i < len - 1; i++) {
for (j = 0; j < len - 1 - i; j++) {
if (arr[j] > arr[j + 1]) {
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
选择排序:
void selection_sort(int arr[], int len) {
int i, j, temp, min_idx;
for (i = 0; i < len - 1; i++) {
min_idx = i;
for (j = i + 1; j < len; j++) {
if (arr[j] < arr[min_idx]) {
min_idx = j;
}
}
temp = arr[i];
arr[i] = arr[min_idx];
arr[min_idx] = temp;
}
}
这两个算法的时间复杂度都是O(n^2),不过在实际应用中,选择排序通常比冒泡排序更快一些。
原文地址: https://www.cveoy.top/t/topic/nukl 著作权归作者所有。请勿转载和采集!