#include<iostream>
using namespace std;
const int N=1e5+10;
int a[N];
void Quicksort(int l,int r)
{
if(l>=r)return;
int i=l,j=r;
int x=a[(l+r+1)>>1];
while(i<j)
{
while(a[j]>=x&&i<j)j--;
while(a[i]<=x&&i<j)i++;
if(i<j)swap(a[i],a[j]);
}
Quicksort(l,j);
Quicksort(j+1,r);
}
int main()
{
int n;
cin>>n;
for(int i=1;i<=n;i++)
cin>>a[i];
Quicksort(1,n);
for(int i=1;i<=n;i++)
cout<<a[i]<<" ";
return 0;
}
出错:自己改了好多遍有死循环的,有内存错误的
能给一个修改后的吗?中间是while形式的,基准数也是取中间