问答详情
源自:7-22 数组排序sort()

关于return a-b 的理解这样是否正确??

我们可以这么理解 return a-b  

如果a>b的话 返回的不管是几,肯定是正数、 

a<b的话肯定是负数。(这里不考虑等于的情况,没意义,排序谁前谁后有区别吗?) 

这个时候再通过sort排序的时候,每次都要计算一次正负值后对两个数排序,这样负数肯定在前,正数在后……

这样,小的在前,大的在后,就是升序排列。

反过来,b-a的话,如果a>b,返回的是负数,这样b就在前面……最后结果就是降序排列

不知道这样理解对不对?


提问者:驰子 2014-11-30 19:35

个回答

  • Alyssa_Lee
    2014-12-10 09:44:15
    已采纳

    因为sort()函数使用的是冒泡排序,冒泡排序会重复地走访要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来,一直重复地进行直到说该数列已经排序完成。

    如果a-b>0(即正数)就把a和b的位置交换,也就是较小的一个数会排到前面;

    如果b-a>0就把a和b的位置交换,也就是较大的一个数会排到前面。

  • dbsg
    2016-08-19 17:04:50

    public void


  • 深秋色
    2014-12-04 20:07:13

    但是为什么不是对a-b的值进行大小排序呢?我在这卡着了,求解

  • 偌颜宁
    2014-12-01 11:55:55

    可以这么理解