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 相关文章推荐
Hadoop中的Python框架的使用指南
Apr 22 Python
Python正则表达式常用函数总结
Jun 24 Python
Python信息抽取之乱码解决办法
Jun 29 Python
python3使用SMTP发送简单文本邮件
Jun 19 Python
华为2019校招笔试题之处理字符串(python版)
Jun 25 Python
Python PyQt5 Pycharm 环境搭建及配置详解(图文教程)
Jul 16 Python
详解python中的模块及包导入
Aug 30 Python
Python实现word2Vec model过程解析
Dec 16 Python
Python 面向对象静态方法、类方法、属性方法知识点小结
Mar 09 Python
浅析Python 简单工厂模式和工厂方法模式的优缺点
Jul 13 Python
Pandas DataFrame求差集的示例代码
Dec 13 Python
openstack中的rpc远程调用的方法
Jul 09 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与SQL注入攻击[三]
2007/04/17 PHP
php获取某个目录大小的代码
2008/09/10 PHP
php FPDF类库应用实现代码
2009/03/20 PHP
PHP中魔术变量__METHOD__与__FUNCTION__的区别
2014/09/29 PHP
PHP 中 DOMDocument保存xml时中文出现乱码问题的解决方案
2016/09/19 PHP
php判断文件上传图片格式的实例详解
2017/09/30 PHP
javascript写的一个链表实现代码
2009/10/25 Javascript
一个简单的js树形菜单
2011/12/09 Javascript
Jquery中val()表单取值赋值的实例代码
2013/08/15 Javascript
javascript如何判断输入的url是否正确
2014/04/11 Javascript
jQuery带箭头提示框tooltips插件集锦
2014/11/17 Javascript
AngularJS中的过滤器filter用法完全解析
2016/04/22 Javascript
DOM 事件的深入浅出(二)
2016/12/05 Javascript
jquery实现焦点轮播效果
2017/02/23 Javascript
JavaScript之排序函数_动力节点Java学院整理
2017/06/30 Javascript
jQuery实现的回车触发按钮事件功能示例
2018/03/25 jQuery
Vue 实现树形视图数据功能
2018/05/07 Javascript
使用jquery DataTable和ajax向页面显示数据列表的方法
2018/08/09 jQuery
Javascript的this详解
2019/03/23 Javascript
vue-cli webpack配置文件分析
2019/05/20 Javascript
Vue+axios+WebApi+NPOI导出Excel文件实例方法
2019/06/05 Javascript
[02:32]DOTA2英雄基础教程 祸乱之源
2013/12/23 DOTA
详解Django定时任务模块设计与实践
2019/07/24 Python
Pyinstaller打包Scrapy项目的实现步骤
2020/09/22 Python
python3爬虫GIL修改多线程实例讲解
2020/11/24 Python
印尼最大的在线购物网站:MatahariMall.com
2016/08/26 全球购物
英国第一职业高尔夫商店:Clickgolf.co.uk
2020/11/18 全球购物
幼儿园园长自我鉴定
2013/10/22 职场文书
电子信息工程自荐信
2014/05/26 职场文书
党支部鉴定意见
2015/06/02 职场文书
《秦兵马俑》教学反思
2016/02/24 职场文书
redis哨兵常用命令和监控示例详解
2021/05/27 Redis
PHP实现rar解压读取扩展包小结
2021/06/03 PHP
「月刊Action」2022年5月号封面公开
2022/03/21 日漫
Python实现提取PDF简历信息并存入Excel
2022/04/02 Python
CSS中float高度塌陷问题的四种解决方案
2022/04/18 HTML / CSS