驰子
2014-11-30 19:35
我们可以这么理解 return a-b
如果a>b的话 返回的不管是几,肯定是正数、
a<b的话肯定是负数。(这里不考虑等于的情况,没意义,排序谁前谁后有区别吗?)
这个时候再通过sort排序的时候,每次都要计算一次正负值后对两个数排序,这样负数肯定在前,正数在后……
这样,小的在前,大的在后,就是升序排列。
反过来,b-a的话,如果a>b,返回的是负数,这样b就在前面……最后结果就是降序排列
不知道这样理解对不对?
因为sort()函数使用的是冒泡排序,冒泡排序会重复地走访要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来,一直重复地进行直到说该数列已经排序完成。
如果a-b>0(即正数)就把a和b的位置交换,也就是较小的一个数会排到前面;
如果b-a>0就把a和b的位置交换,也就是较大的一个数会排到前面。
public void
但是为什么不是对a-b的值进行大小排序呢?我在这卡着了,求解
可以这么理解
JavaScript进阶篇
468190 学习 · 21891 问题
相似问题