python计数排序和基数排序算法实例


Posted in Python onApril 25, 2014

一、计数排序

计数排序(Counting sort)是一种稳定的排序算法

算法的步骤如下:
找出待排序的数组中最大和最小的元素
统计数组中每个值为i的元素出现的次数,存入数组C的第i项
对所有的计数累加(从C中的第一个元素开始,每一项和前一项相加)
反向填充目标数组:将每个元素i放在新数组的第C(i)项,每放一个元素就将C(i)减去1
当输入的元素是 n 个 0 到 k 之间的整数时,计数排序的时间复杂度为O(N+K),空间复杂度为O(N+K)。当K不是很大时,这是一个很有效的线性排序算法。

以下是测试代码:

#-*- coding:utf8 -*-
import randomdef jishu(data, max):
    """
    基数排序:当输入的元素是 n 个 0 到 k 之间的整数时(k不能太大,即max不能太大)
    @param data: 需要排序的数组
    @param max: 最大的数
    """
    result = [None for i in xrange(len(data))]  # 最后的结果
    c = [0 for i in range(max+1)]
    # 用数组c统计每个值=d的元素个数
    for d in data:
        c[d] = c[d] + 1

    # c[i]表示data中值<=i 的元素个数
    for i in range(1, max+1):
        c[i] = c[i] + c[i-1]
    # 在将C中的元素倒着打印出来就是排序好的
    for j in xrange(len(data)-1, -1, -1):
        result[c[data[j]]-1] = data[j]
        c[data[j]] = c[data[j]] ? 1
    return result
 
if __name__ == '__main__':
    #制造1000个0到100的数字
    print jishu([random.randint(0, 100) for i in range(1000)], 100)

二、基数排序

基数排序排序(英语:Radix sort)是一种非比较型整数排序算法,其原理是将整数按位数切割成不同的数字,然后按每个位数分别比较。

它是这样实现的:将所有待比较数值(正整数)统一为同样的数位长度,数位较短的数前面补零。然后,从最低位开始,依次进行一次排序。这样从最低位排序一直到最高位排序完成以后, 数列就变成一个有序序列。
基数排序的方式可以采用LSD(Least significant digital)或MSD(Most significant digital),LSD的排序方式由键值的最右边开始,而MSD则相反,由键值的最左边开始。

以下是一个测试用例:

#-*- coding:utf8 -*-
import random
def jichu(data, length):
    """
    基数排 lsd 
    @param data: 需要排列的组合
    @param length: 最大的数据是几位
    """
    for l in xrange(length):
        s = [[] for i in xrange(10)]  
        for d in data:
            s[d/(10**l) % 10].append(d)
        data = [d for s_list in s for d in s_list]
    return data
 
if __name__ == '__main__':
    list = [random.randint(1, 99999999) for i in xrange(99)]  # 制造99个数据
    print jichu(list, 8)

Python 相关文章推荐
Python中转换角度为弧度的radians()方法
May 18 Python
回调函数的意义以及python实现实例
Jun 20 Python
使用python和Django完成博客数据库的迁移方法
Jan 05 Python
Python重新加载模块的实现方法
Oct 16 Python
python绘制中国大陆人口热力图
Nov 07 Python
python生成多个只含0,1元素的随机数组或列表的实例
Nov 12 Python
Python 静态方法和类方法实例分析
Nov 21 Python
keras.utils.to_categorical和one hot格式解析
Jul 02 Python
Python识别处理照片中的条形码
Nov 16 Python
python实现跨年表白神器--你值得拥有
Jan 04 Python
如何用python爬取微博热搜数据并保存
Feb 20 Python
Python基础之hashlib模块详解
May 06 Python
python处理圆角图片、圆形图片的例子
Apr 25 #Python
python实现的阳历转阴历(农历)算法
Apr 25 #Python
Python实现的简单万年历例子分享
Apr 25 #Python
python实现simhash算法实例
Apr 25 #Python
python实现DNS正向查询、反向查询的例子
Apr 25 #Python
python网络编程之TCP通信实例和socketserver框架使用例子
Apr 25 #Python
python网络编程之UDP通信实例(含服务器端、客户端、UDP广播例子)
Apr 25 #Python
You might like
php 分页原理详解
2009/08/21 PHP
php代码书写习惯优化小结
2013/06/20 PHP
教你如何快捷的使用cmd访问mysql小技巧
2014/05/26 PHP
PHP表单数据写入MySQL数据库的代码
2016/05/31 PHP
PHP7内核之Reference详解
2019/03/14 PHP
PHP 进程池与轮询调度算法实现多任务的示例代码
2019/11/26 PHP
ExtJS 简介 让你知道extjs是什么
2008/12/29 Javascript
JavaScript中“+”的陷阱深刻理解
2012/12/04 Javascript
JavaScript Math.ceil() 函数使用介绍
2013/12/11 Javascript
教你如何使用firebug调试功能了解javascript闭包和this
2015/03/04 Javascript
jQuery插件Slider Revolution实现响应动画滑动图片切换效果
2015/06/05 Javascript
js获取本机操作系统类型的两种方法
2015/12/19 Javascript
详解JavaScript对象类型
2016/06/16 Javascript
ES6中Math对象新增的方法实例详解
2017/04/25 Javascript
详解基于Angular4+ server render(服务端渲染)开发教程
2017/08/28 Javascript
JavaScript数组排序reverse()和sort()方法详解
2017/12/24 Javascript
bootstrap 点击空白处popover弹出框隐藏实例
2018/01/24 Javascript
jQuery实现的简单图片轮播效果完整示例
2018/02/08 jQuery
KnockoutJS数组比较算法实例详解
2019/11/25 Javascript
jQuery实现购物车全功能
2021/01/11 jQuery
python字符串的方法与操作大全
2018/01/30 Python
python 获取字符串MD5值方法
2018/05/29 Python
使用python判断你是青少年还是老年人
2018/11/29 Python
Python3批量生成带logo的二维码方法
2019/06/24 Python
python实现将一维列表转换为多维列表(numpy+reshape)
2019/11/29 Python
使用python 将图片复制到系统剪贴中
2019/12/13 Python
如何基于python操作excel并获取内容
2019/12/24 Python
Python爬虫爬取糗事百科段子实例分享
2020/07/31 Python
Python 解析xml文件的示例
2020/09/29 Python
详解基于python的全局与局部序列比对的实现(DNA)
2020/10/07 Python
室内设计专业学生的自我评价分享
2013/11/27 职场文书
会计电算化专业毕业生推荐信
2013/12/24 职场文书
岗位廉洁从政承诺书
2014/03/27 职场文书
正风肃纪查摆剖析材料
2014/10/10 职场文书
商务代表岗位职责
2015/02/15 职场文书
Vue OpenLayer测距功能的实现
2022/04/20 Vue.js