地瓜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 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。