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实现逆波兰计算表达式实例详解
May 06 Python
python flask 多对多表查询功能
Jun 25 Python
python脚本替换指定行实现步骤
Jul 11 Python
python 不以科学计数法输出的方法
Jul 16 Python
详解Python中的type和object
Aug 15 Python
对python:threading.Thread类的使用方法详解
Jan 31 Python
在win10和linux上分别安装Python虚拟环境的方法步骤
May 09 Python
Python实现RGB与HSI颜色空间的互换方式
Nov 27 Python
python GUI库图形界面开发之PyQt5布局控件QGridLayout详细使用方法与实例
Mar 06 Python
Python turtle库的画笔控制说明
Jun 28 Python
Python实现扫码工具的示例代码
Oct 09 Python
Numpy数组的广播机制的实现
Nov 03 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打印输出棋盘的实现方法
2014/12/23 PHP
完美解决JS中汉字显示乱码问题(已解决)
2006/12/27 Javascript
jquery animate 动画效果使用说明
2009/11/04 Javascript
某人初学javascript的时候写的学习笔记
2010/12/30 Javascript
javascript使用百度地图api和html5特性获取浏览器位置
2014/01/10 Javascript
jQuery匹配文档链接并添加class的方法
2015/06/26 Javascript
jquery实现右侧栏菜单选择操作
2016/03/04 Javascript
jQuery Ajax全解析
2017/02/13 Javascript
javascript中replace使用方法总结
2017/03/01 Javascript
vue mintui-Loadmore结合实现下拉刷新和上拉加载示例
2017/10/12 Javascript
js原生实现移动端手指滑动轮播图效果的示例
2018/01/02 Javascript
jQuery+ajax读取json数据并按照价格排序示例
2018/03/28 jQuery
JS简单实现查看文档创建日期、修改日期和文档大小的方法示例
2018/04/08 Javascript
小程序开发中如何使用async-await并封装公共异步请求的方法
2019/01/20 Javascript
Vue实战教程之仿肯德基宅急送App
2019/07/19 Javascript
JQuery常用简单动画操作方法回顾与总结
2019/12/07 jQuery
node.js +mongdb实现登录功能
2020/06/18 Javascript
详解vue v-model
2020/08/31 Javascript
[01:06:07]2014 DOTA2国际邀请赛中国区预选赛5.21 DT VS CIS
2014/05/22 DOTA
python发布模块的步骤分享
2014/02/21 Python
日常整理python执行系统命令的常见方法(全)
2015/10/22 Python
python实现爬虫统计学校BBS男女比例之数据处理(三)
2015/12/31 Python
Python获取CPU、内存使用率以及网络使用状态代码
2018/02/08 Python
python 爬取学信网登录页面的例子
2019/08/13 Python
CSS3动画animation实现云彩向左滚动
2014/05/09 HTML / CSS
Bluebella美国官网:英国性感内衣品牌
2018/10/04 全球购物
KIKO MILANO西班牙官网:意大利领先的化妆品和护肤品品牌
2019/05/03 全球购物
金融专业应届生求职信
2013/11/02 职场文书
《再别康桥》教学反思
2014/02/12 职场文书
农业局学习党的群众路线教育实践活动心得体会
2014/03/07 职场文书
函授本科个人自我鉴定
2014/03/25 职场文书
国庆节标语大全
2014/10/08 职场文书
道歉信怎么写
2015/05/12 职场文书
2015领导干部廉洁自律工作总结
2015/07/23 职场文书
教你使用TensorFlow2识别验证码
2021/06/11 Python
mysql事务隔离级别详情
2021/10/24 MySQL