Mr-Luer 2017-07-31 15:33 采纳率: 33.3%
浏览 1498
已采纳

快速排序结果为什么不正确

int sort(int *a ,int begin ,int end)
{
int low[10] ;
int up[10] ;
int upcnt =0 ;
int lowcnt =0 ;

int c = a[begin] ;//选择第一个元素作为已经排序好的元素

for(int i = begin+1 ;i<=end ;++i)
{
    if(a[i]>=c)
        up[upcnt++] = a[i] ;//大于该该元素的放在up
    else
        low[lowcnt++] = a[i] ;//小于该元素的放于low
}
for(int i =0 ;i< lowcnt ;++i)//写回
{
    a[begin+i] = low[i] ;
}

a[begin+lowcnt] = c ;

for(int i=0 ;i<upcnt ;++i)
{
    a[begin+i+lowcnt+1] = a[i] ;
}


return begin +lowcnt  ;//返回有序元素位置

}

void quicksort(int *a, int begin ,int end)
{

if(begin<end)
{
    int n = sort(a,begin,end) ;

    if(n>begin)
    quicksort(a,begin,n-1) ;

    if(n<end)
    quicksort(a,n+1,end) ;  

}
else
    return ;

}

void main()
{
int a [7] ={10,33,5,63,9,8,1} ;
quicksort(a,0,6) ;

for(int i=0 ;i<6 ;++i)
    cout<<a[i]<<" " ;

}

  • 写回答

3条回答 默认 最新

  • cloudyzhao 2017-08-01 01:06
    关注

    a[begin+i+lowcnt+1] = a[i] ;
    这句应该错了吧

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog