地瓜1996 2021-07-22 10:17 采纳率: 100%
浏览 57
已采纳

关于JAVA 选择排序

看 c.biancheng.net 给的关于选择排序的例程,有个小问题:

1     int[] number = {13,15,24,99,4,1};
2     String end = "\n";
3     int index;
4     for (int i = 1;i < number.length;i++) {
5         index = 0;
6         for(int j = 1;j <= number.length-i;j++) {
7             if (number[j] > number[index]) {
8                 index = j;    // 查找最大值
9             }
10        }
11    end = number[index] + " " + end;    // 定位已排好的数组元素
12    int temp = number[number.length-i];
13    number[number.length-1] = number[index];
14    number[index] = temp;
15    System.out.print("【");
16    for (int j = 0;j < number.length-i;j++) {
17        System.out.print(number[j]+" ");
18    }
19    System.out.print("】"+end);
}

问题就在第13行,为什么是 number[number.length - 1] ?中括号里为什么是 -1 而不是 - i ?更奇怪的是,两种情况下运行得到的结果都是正确的……这是为什么呀?

Thanks!

  • 写回答

2条回答 默认 最新

  • CSDN专家-Time 2021-07-22 10:37
    关注
    • i 并不正确。
      算法从1-6 数组中提取第 1个元素.
      理应从2-6 找数,比较大小。
      而不是2->(6-1)
      只是凑巧,5号位,6号位的数字都太小了不会被改变位置。
      所以你看起来写成i也没关系。实际是有问题的。
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已采纳回答 7月22日
  • 创建了问题 7月22日

悬赏问题

  • ¥15 python的qt5界面
  • ¥15 无线电能传输系统MATLAB仿真问题
  • ¥50 如何用脚本实现输入法的热键设置
  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀
  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100