AcWing 785. 快速排序
原题链接
简单
作者:
人生真是寂寞如雪啊
,
2019-12-16 13:02:49
,
所有人可见
,
阅读 928
#include <iostream>
using namespace std;
//yxc的板
void quick_sort(int a[], int l, int r) {
if (l >= r) return;
int i = l - 1, j = r + 1, x = a[l + r >> 1]; //l+r 向右移一位,相当于2的一次,就是除2
while (i < j) {
do i ++ ; while (a[i] < x);
do j -- ; while (a[j] > x);
if (i < j) swap(a[i], a[j]);
}
quick_sort(a, l, j), quick_sort(a, j + 1, r);
}
const int N = 100010;
int main() {
int n;
cin >> n;
int a[N];
for (int i = 0; i < n; i++) {
scanf("%d",&a[i]);
}
quick_sort (a,0,n-1);
for (int i = 0; i < n; i ++ )
printf("%d ",a[i]);
return 0;
}