前言:
比较排序的下界为o(nlogn)。那么有没有时间复杂度为o(n)的线性时间排序算法呢?在一定的假设条件下,是有更快的排序算法的,下面介绍的计数排序和桶排序等都是线性时间排序算法。
1、计数排序
计数排序便是很基础的一种线性时间排序,它是基数排序的基础。基本思想是:对每一个元素x,确定小于x的元素个数,就可以把x直接放到它在有序序列中的位置上。过程描述:假设待排序序列a中值的范围[0,k],其中k表示待排序序列中的最大值。首先用一个辅助数组count记录各个值在a中出现的次数,比如count[i]表示i在a中的个数。然后依次改变count中元素值,使count[i]表示a中不大于i的元素个数。然后从后往前扫描a数组,a中的元素根据count中的信息直接放到辅助数组b中。最后把有序序列b复制到a。