Iseuwei
2016-04-03 16:36
采纳率: 100%
浏览 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条回答 默认 最新

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

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

    已采纳该答案
    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题