ISEUWEI
Iseuwei
采纳率100%
2016-04-03 16:36 阅读 1.5k
已采纳

C语言冒泡排序的小问题

void bubblesort(intArr*ia){
int i,j,t,n=ia->cur;
for(i=n;i>2;i--)
for(j=1;j if(ia->pt[j]>ia->pt[j-1]){
t=ia->pt[j-1];
ia->pt[j-1]=ia->pt[j];
ia->pt[j]=t;
}
上面这段是算法其中的排序部分,对长度为ia->cur的数组排序,结果似乎有点问题,结果后两位有时错位,另外结果是降序,但代码似乎是升序,各位大神给点建议

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

1条回答 默认 最新

  • 已采纳
    oiu1010110 白日梦想jun 2016-04-04 16:23

    下标j的值大于j-1时,交换。就是降序啊。你看看是不是要>=2呢

    点赞 评论 复制链接分享

相关推荐