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 用verilog实现tanh函数和softplus函数
  • ¥15 Hadoop集群部署启动Hadoop时碰到问题
  • ¥15 求京东批量付款能替代天诚
  • ¥15 slaris 系统断电后,重新开机后一直自动重启
  • ¥15 QTableWidget重绘程序崩溃
  • ¥15 谁能帮我看看这拒稿理由啥意思啊阿啊
  • ¥15 关于vue2中methods使用call修改this指向的问题
  • ¥15 idea自动补全键位冲突
  • ¥15 请教一下写代码,代码好难
  • ¥15 iis10中如何阻止别人网站重定向到我的网站