快排基准可以随便选吗?边界问题怎么看?有大佬能帮我看看我的代码哪错了吗?

 

#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形式的,基准数也是取中间

你好,我是有问必答小助手,非常抱歉,本次您提出的有问必答问题,技术专家团超时未为您做出解答

本次提问扣除的有问必答次数,将会以问答VIP体验卡(1次有问必答机会、商城购买实体图书享受95折优惠)的形式为您补发到账户。

​​​​因为有问必答VIP体验卡有效期仅有1天,您在需要使用的时候【私信】联系我,我会为您补发。