Sort函数比较复杂,底层用到了改进快速排序(用3点中值法,确定枢轴),堆排序,插入排序。
总体来说,sort是以快速排序算法为基础进行优化的,优化主要体现在3个方面:
1、任何元素都可以被当做枢轴,但是其合适与否却会影响效率。为了避免元素初始不够随机所带来的恶化效应,取整个队列首、尾、中央三个位置的元素,以其中值作为枢轴。
2、不当的枢轴选择会导致快速排序的效率恶化为O(N2),此种现象的表现是递归深度过深,用序列长度的函数限制递归深度(2*lgN),当超过该值时,采用堆排序。
这里对2*lgN稍微解释下,其实快速排序的递归表现为对序列的切分,最终的效果是切割成为长度为1的区间,最理想的效果是每次都折半切分,那么递归深度为lgN;最差的情况,递归深度为N;实际上由于输入序列的随机性,深度在lgN~N之间,2*lgN是人为设置的一个界限。
这个思路也可以用来分析大部分具有NlgN复杂度的排序算法的复杂度。对每个元素,都存在lgN的递归代价,那么N个元素复杂度为N*lgN。注意这是最理想的,实际上会存在一个大于1的系数。堆排序、归