计数排序算法(Python 实现)

概念

计数排序算法(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 我偷了懒,直接把最大值传入了

转载于:https://my.oschina.net/hfanG/blog/2885776

你可能感兴趣的:(计数排序算法(Python 实现))