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条件和循环的使用方法
Nov 01 Python
Python Web框架Flask下网站开发入门实例
Feb 08 Python
Python中的with...as用法介绍
May 28 Python
详解在Python的Django框架中创建模板库的方法
Jul 20 Python
微信跳一跳辅助python代码实现
Jan 05 Python
Python中if elif else及缩进的使用简述
May 31 Python
浅谈python函数调用返回两个或多个变量的方法
Jan 23 Python
python算法与数据结构之冒泡排序实例详解
Jun 22 Python
Python获取好友地区分布及好友性别分布情况代码详解
Jul 10 Python
Python OpenCV读取显示视频的方法示例
Feb 20 Python
PyTorch梯度裁剪避免训练loss nan的操作
May 24 Python
如何在Python项目中引入日志
May 31 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调用Java对象的方法
2006/10/09 PHP
PHP程序员面试 切忌急功近利(更需要注重以后的发展)
2010/09/01 PHP
php读取文件内容的三种可行方法示例介绍
2014/02/08 PHP
php和jquery实现地图区域数据统计展示数据示例
2014/02/12 PHP
CodeIgniter多语言实现方法详解
2016/01/20 PHP
用Javascript读取中文COOKIE的解决办法
2007/02/15 Javascript
使用js 设置url参数
2013/07/08 Javascript
给超链接添加特效鼠标移动展示提示信息且随鼠标移动
2013/10/17 Javascript
使用jquery解析XML的方法
2014/09/05 Javascript
Jquery检验手机号是否符合规则并根据手机号检测结果将提交按钮设为不同状态
2015/11/26 Javascript
js 创建对象 经典模式全面了解
2016/08/16 Javascript
javascript 分号总结及详细介绍
2016/09/24 Javascript
浅谈js的ajax的异步和同步请求的问题
2016/10/07 Javascript
浅析Node.js:DNS模块的使用
2016/11/23 Javascript
浅谈js函数的多种定义方法与区别
2016/11/29 Javascript
在vue项目中安装使用Mint-UI的方法
2017/12/27 Javascript
基于js文件加载优化(详解)
2018/01/03 Javascript
JS/jQuery实现简单的开关灯效果【案例】
2019/02/19 jQuery
vue+elementUI实现表单和图片上传及验证功能示例
2019/05/14 Javascript
webpack4.0+vue2.0利用批处理生成前端单页或多页应用的方法
2019/06/28 Javascript
使用Phantomjs和Node完成网页的截屏快照的方法
2019/07/16 Javascript
Vue如何获取数据列表展示
2019/12/11 Javascript
vue中的双向数据绑定原理与常见操作技巧详解
2020/03/16 Javascript
python中pandas.DataFrame排除特定行方法示例
2017/03/12 Python
python对excel文档去重及求和的实例
2018/04/18 Python
python 比较字典value的最大值的几种方法
2020/04/17 Python
英国最大的美妆产品在线零售商之一:Beauty Bay
2017/09/29 全球购物
意大利火车票和铁路通行证专家:ItaliaRail
2019/01/22 全球购物
SportsDirect.com新加坡:英国第一体育零售商
2019/03/30 全球购物
酒店总经理工作职责
2013/12/13 职场文书
教你打造完美的创业计划书
2014/01/06 职场文书
大学生冰淇淋店商业计划书
2014/01/14 职场文书
人事部经理岗位职责
2014/03/07 职场文书
优秀学生干部个人事迹材料
2014/06/02 职场文书
商务经理岗位职责
2014/08/03 职场文书
搬迁通知
2015/04/20 职场文书