美文网首页
Python实现计数排序

Python实现计数排序

作者: 风筝flying | 来源:发表于2018-10-11 15:45 被阅读14次

计数排序

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

算法思想

计数排序的基本思想在于给定的输入序列中的每一个元素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))

代码注释

  • 中间数组的作用是用来统计arr中每个元素的出现次数,中间数组的下标就是arr中元素的值,中间数组的值就是arr中该下标值出现的次数
  • 之所以要获取arr的最大值和最小值,是因为需要排序的一定范围的整数不一定是从0开始,此时为避免空间位置浪费,中间数组的长度是是数列最大值和最小值的差+1,此时最小值作为一个偏移量存在
  • 第一次遍历:用来遍历arr的每个元素,统计每个元素的出现次数,存入中间数组(下标是arr中的元素值,值是该元素在arr中的出现次数)
  • 第二次遍历:遍历中间数组,每个位置的值=当前值+前一个位置的值,用来统计出小于等于当前下标的元素个数
  • 第三次遍历:反向遍历arr的每个元素,找到该元素值在中间数组的对应下标,以这个中间数组的值作为结果数组的下标,将该元素存入结果数组

空间复杂度和时间复杂度

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

局限性

  • 当数列的最大和最小值差距过大时,并不适用计数排序
  • 当数列元素不是整数,并不适用计数排序

相关文章

  • python实现计数排序(CountSort)

    python实现【计数排序】(CountSort) 算法原理及介绍 计数排序不是基于比较的排序算法,其核心在于将输...

  • 排序

    排序 快速排序 归并排序 计数排序 Python实现 理解 详解 稳定:如果a原本在b前面,而a=b,排序之后a仍...

  • Python实现计数排序

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

  • python实现桶排序(BucketSort)

    python实现【桶排序】(BucketSort) 算法原理及介绍 桶排序是计数排序的升级版。它利用了函数的映射关...

  • 排序算法详细代码实现

    算法分类 算法时间复杂度 选择排序 插入排序 C++实现 Python实现 冒泡排序 Python实现 归并排序 ...

  • 排序算法Java实现

    本文会通过Java语言实现:冒泡排序,插入排序,选择排序,归并排序,快速排序,桶排序,计数排序,基数排序,希尔排序...

  • 基本排序算法的Python实现

    本篇主要实现九(八)大排序算法,分别是冒泡排序,插入排序,选择排序,希尔排序,归并排序,快速排序,堆排序,计数排序...

  • 算法-排序算法总结

    排序类型总结 1 排序算法基础实现 2 排序算法应用 2.1 基础排序 2.2 计数排序应用 2.3 快排应用 2...

  • 利用Python统计连续登录N天或以上用户

    在有些时候,我们需要统计连续登录N天或以上玩家,这里采用python通过分组排序、分组计数等步骤实现该功能,具体如...

  • 排序算法 --- 计数排序

    前面说的那些排序算法,都是要通过比较来实现的。排序还能不通过比较来实现?是的,计数排序就是这么神奇。 一、排序思想...

网友评论

      本文标题:Python实现计数排序

      本文链接:https://www.haomeiwen.com/subject/suybaftx.html