c语言多个数字大小排序
时间: 2024-10-02 16:03:59 浏览: 42
在C语言中,对多个数字进行排序通常可以使用选择排序、插入排序、冒泡排序、快速排序、归并排序等算法。这里以最常见的冒泡排序和快速排序为例讲解:
1. **冒泡排序**:
冒泡排序是一种简单直观的排序算法,它重复地遍历待排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。
```c
void bubble_sort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - 1 - i; j++) {
if (arr[j] > arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
```
2. **快速排序**:
快速排序是一种分治策略的典型应用,通过选取一个基准值(pivot),将数组分为两部分,一部分的所有元素都小于基准值,另一部分的所有元素都大于基准值,然后递归地对这两部分进行排序。
```c
void quick_sort(int arr[], int low, int high) {
if (low < high) {
int pivot_index = partition(arr, low, high);
quick_sort(arr, low, pivot_index - 1);
quick_sort(arr, pivot_index + 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++;
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
int temp = arr[i + 1];
arr[i + 1] = arr[high];
arr[high] = temp;
return (i + 1);
}
```
阅读全文