qq_45690075
2021-04-19 18:54
采纳率: 100%
浏览 40
已采纳

JAVA选择排序中,使用循环嵌套,结果与想象的刚好相反?


        int[] a = new int[]{16, 62, 68, 82, 65, 9};

        for (int i = 0; i < a.length; i++) {
            System.out.println(a[i]);
        }
        System.out.println("");

        for (int j = 0; j < a.length; j++) {
            for (int n = 0; n < a.length; n++) {
                if (a[j] > a[n]) {
                   int c = a[j];
                    a[j] = a[n];
                    a[n] = c;

                }
            }
        }
        for (int m = 0; m < a.length; m++) {
            System.out.println(a[m]);

        }
    }
}
  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 收藏
  • 邀请回答

4条回答 默认 最新

  • 已采纳

     n 应该从j+1开始循环
    for (int n = j+1; n < a.length; n++) {
     

    n 不能小于 j,这样才不会重复比较
    否则,j为0,n为1 时a[j] 与 a[n]互换,
    等到,j为1,n为0时 a[j] 与 a[n]又互换回去了。

    评论
    解决 2 无用
    打赏 举报
查看更多回答(3条)

相关推荐 更多相似问题