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]);
}
}
}JAVA选择排序中,使用循环嵌套,结果与想象的刚好相反?
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
4条回答 默认 最新
CSDN专家-天际的海浪 2021-04-19 19:17关注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无用