AcWing 785. 快速排序
Posted MangataTS
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了AcWing 785. 快速排序相关的知识,希望对你有一定的参考价值。
题目连接
https://www.acwing.com/problem/content/787/
思路
找一个分界点,然后坐标左边都小于他,右边都大于他,体现分治的思想
我们有一个l和r指针,都往中间走,然后左边遇到大于我们选中的x值就停下来,右边就遇到小于我们选择的x值就停下来,然后交换两数,然后重复这个过程,知道两个指针相遇就完成了我们的划分,即x左边的都小于等于x,x右边的都大于等于x
#include<bits/stdc++.h>
using namespace std;
const int N = 1e6+10;
int a[N];
void mysort(int a[],int l,int r)
if(l >= r) return;
int x = a[l+r>>1],i=l-1,j=r+1;
while(i < j)
while(a[++i] < x);
while(a[--j] > x);
if(i < j) swap(a[i],a[j]);
mysort(a,l,j);
mysort(a,j+1,r);
int main()
int n;
scanf("%d",&n);
for (int i = 0; i < n; i ++ )
scanf("%d",&a[i]);
mysort(a,0,n-1);
for (int i = 0; i < n; i ++ )
printf("%d ",a[i]);
return 0;
以上是关于AcWing 785. 快速排序的主要内容,如果未能解决你的问题,请参考以下文章