使用C语言实现快速排序
时间: 2023-12-15 13:32:03 浏览: 87
用C语言实现快速排序
以下是使用C语言实现快速排序的代码示例:
```c
#include <stdio.h>
// 交换两个元素的值
void swap(int *a, int *b) {
int temp = *a;
*a = *b;
*b = temp;
}
// 获取基准值的位置
int partition(int arr[], int low, int high) {
int pivot = arr[low]; // 以第一个元素为基准值
while (low < high) {
while (low < high && arr[high] >= pivot) {
high--;
}
swap(&arr[low], &arr[high]);
while (low < high && arr[low] <= pivot) {
low++;
}
swap(&arr[low], &arr[high]);
}
return low;
}
// 快速排序
void quickSort(int arr[], int low, int high) {
if (low < high) {
int pivotPos = partition(arr, low, high);
quickSort(arr, low, pivotPos - 1);
quickSort(arr, pivotPos + 1, high);
}
}
int main() {
int arr[] = {5, 3, 8, 4, 2, 7, 1, 10, 6, 9};
int len = sizeof(arr) / sizeof(arr[0]);
quickSort(arr, 0, len - 1);
for (int i = 0; i < len; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
阅读全文