C语言实现对于给定的无序序列,请使用快速排序方法进行排序。
时间: 2023-07-08 19:50:42 浏览: 132
好的,下面是C语言实现快速排序的代码:
```c
#include <stdio.h>
void quick_sort(int arr[], int left, int right) {
if (left >= right) {
return;
}
int i = left, j = right, pivot = arr[left];
while (i < j) {
while (i < j && arr[j] >= pivot) j--;
if (i < j) arr[i++] = arr[j];
while (i < j && arr[i] < pivot) i++;
if (i < j) arr[j--] = arr[i];
}
arr[i] = pivot;
quick_sort(arr, left, i - 1);
quick_sort(arr, i + 1, right);
}
int main() {
int arr[] = {4, 2, 1, 6, 3, 5};
int n = sizeof(arr) / sizeof(arr[0]);
quick_sort(arr, 0, n - 1);
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
这个程序实现了一个名为quick_sort的函数,它接收一个整数数组arr、左边界left和右边界right作为参数。首先判断左边界是否大于等于右边界,如果是,则直接返回。否则,选择左边界的元素作为基准元素pivot,使用双指针i和j遍历整个区间,将小于pivot的元素移到左边,大于等于pivot的元素移到右边,最终将pivot插入到i的位置。然后递归地对左右两个子区间进行快速排序。
在main函数中,我们定义了一个数组arr,调用quick_sort函数对其进行排序,并输出排序后的结果。
例如,对于数组{4, 2, 1, 6, 3, 5},调用quick_sort(arr, 0, n - 1),会先选择4作为pivot,将数组分成左右两个子区间{2, 1, 3}和{6, 5},然后递归地对这两个子区间进行快速排序,最终得到{1, 2, 3, 4, 5, 6}。
阅读全文