C++ STL 排序源码详解(二)

         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的系数。堆排序、归

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值