概念
计数排序算法(Counting Sort)基于比较的排序算法,其核心在于将输入的数据值转化为键存储在额外开辟的数组空间中。 作为一种线性时间复杂度的排序,计数排序要求输入的数据必须是有确定范围的整数。
过程
- 找出待排序的数组中最大和最小的元素;
- 统计数组中每个值为i的元素出现的次数,存入数组C的第i项;
- 对所有的计数累加(从C中的第一个元素开始,每一项和前一项相加);
- 反向填充目标数组:将每个元素i放在新数组的第C(i)项,每放一个元素就将C(i)减去1。
Code
def count_sort(l, max_value):
result = []
container = [0 for _ in range(0, max_value + 1)]
for one in l:
container[one] += 1
for index in range(0, len(container)):
while container[index] > 0:
result.append(index)
container[index] -= 1
return result
NOTE 我偷了懒,直接把最大值传入了