从小到大排序 C语言
时间: 2024-09-12 19:01:17 浏览: 42
用选择法对个数排序由小到大-c语言程序设计
在C语言中,实现数组或链表等数据结构从小到大排序,通常可以使用多种算法。以下是一些基本的排序算法,它们可以用来实现从小到大排序:
1. 冒泡排序:通过重复交换相邻元素,如果它们的顺序错误,则进行交换,直到没有更多交换需要进行,整个列表就排序好了。
```c
void bubbleSort(int arr[], int n) {
int i, j, temp;
for (i = 0; i < n-1; i++) {
for (j = 0; j < n-i-1; j++) {
if (arr[j] > arr[j+1]) {
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
```
2. 选择排序:每次从未排序的部分中选出最小的元素,放在已排序部分的末尾,直至所有元素都排序完成。
```c
void selectionSort(int arr[], int n) {
int i, j, min_idx, temp;
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;
temp = arr[min_idx];
arr[min_idx] = arr[i];
arr[i] = temp;
}
}
```
3. 插入排序:通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。
```c
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;
}
}
```
4. 快速排序:选择一个元素作为“基准”(pivot),重新排列数组元素,所有比基准小的元素摆放在基准前面,所有比基准大的元素摆放在基准后面,然后递归地在基准前后的子序列上重复这个过程。
```c
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 <= high - 1; j++) {
if (arr[j] < pivot) {
i++;
swap(&arr[i], &arr[j]);
}
}
swap(&arr[i + 1], &arr[high]);
return (i + 1);
}
void swap(int* a, int* b) {
int t = *a;
*a = *b;
*b = t;
}
```
这些算法各有优缺点,适用于不同大小和特性的数据集。冒泡排序简单,但是效率低,适用于小型数据集;快速排序在平均情况下效率很高,是最常用的排序算法之一,但最坏情况下效率较低;选择排序和插入排序则介于两者之间。具体选择哪一种算法取决于具体的应用场景和性能要求。
阅读全文