Python实现计数排序

2018-10-11  本文已影响14人  风筝flying

计数排序

计数排序是一个非基于比较的排序算法,优势在于在对一定范围内的整数排序时,快于基于比较的排序算法。

算法思想

计数排序的基本思想在于给定的输入序列中的每一个元素x,确定该序列中值小于等于x元素的个数,然后将x直接存放到最终的排序序列的正确位置上。

Python代码

环境

Python3.7

代码

# --*-- coding: utf-8 --*--
def CountingSort(arr):
    #检查入参类型
    if not isinstance(arr,(list)):
        raise TypeError('error para type')
    #获取arr中的最大值和最小值
    maxNum=max(arr)
    minNum=min(arr)
    #以最大值和最小值的差作为中间数组的长度,并构建中间数组,初始化为0
    length=maxNum-minNum+1
    tempArr=[0 for i in range(length)]
    #创建结果List,存放排序完成的结果
    resArr=list(range(len(arr)))
    #第一次循环遍历
    for num in arr:
        tempArr[num-minNum]+=1
    #第二次循环遍历
    for j in range(1,length):
        tempArr[j]=tempArr[j]+tempArr[j-1]
    #第三次循环遍历
    for i in range(len(arr)-1,-1,-1):
        resArr[tempArr[arr[i]-minNum]-1]=arr[i]
        tempArr[arr[i]-minNum]-=1
    return resArr
if __name__=='__main__':
    arr=[12,25,26,13,14,25,12,17,18,14]
    print(CountingSort(arr))

代码注释

空间复杂度和时间复杂度

假定原始数列的规模是N,最大值和最小值的差是M,计数排序的时间复杂度是O(N+M),如果不考虑结果数组,只考虑中间数组大小的话,空间复杂度是O(M)

局限性

上一篇 下一篇

猜你喜欢

热点阅读