#include<iostream>
using namespace std;
const int N = 100010; //定义数组长度上限
int q[N]; //待排序数组
void quick_sort(int q[], int l, int r) {
if (l >= r) {
return;
}
int i = l - 1, j = r + 1, x = q[(l + r) >> 1];
while (i < j) {
while (q[++i] < x);
while (q[--j] > x);
if (i < j) {
swap(q[i], q[j]);
}
}
quick_sort(q, l, j);
quick_sort(q, j + 1, r);
}
int main() {
int n = 0;
scanf_s("%d", &n);
for (int i = 0; i < n; i++) {
scanf_s("%d", &q[i]);
}
quick_sort(q, 0, n - 1);
for (int i = 0; i < n; i++) {
printf("%d ", q[i]);
}
return 0;
}
快速排序——quick_sort(采用递归)
最新推荐文章于 2024-10-07 19:01:55 发布