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内置函数之filter map reduce介绍
Nov 30 Python
Python使用shelve模块实现简单数据存储的方法
May 20 Python
Python实现栈的方法
May 26 Python
Eclipse中Python开发环境搭建简单教程
Mar 23 Python
python3.4.3下逐行读入txt文本并去重的方法
Apr 29 Python
使用Python的Dataframe取两列时间值相差一年的所有行方法
Jul 10 Python
使用Python向C语言的链接库传递数组、结构体、指针类型的数据
Jan 29 Python
Pycharm连接远程服务器并实现远程调试的实现
Aug 02 Python
pytorch 多分类问题,计算百分比操作
Jul 09 Python
pycharm 添加解释器的方法步骤
Aug 31 Python
Matplotlib配色之Colormap详解
Jan 05 Python
python 使用OpenCV进行简单的人像分割与合成
Feb 02 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批量删除数据
2007/01/18 PHP
php 无限分类的树类代码
2009/12/03 PHP
php一个找二层目录的小东东
2012/08/02 PHP
PHP生成图片验证码、点击切换实例
2014/06/25 PHP
PHP简单读取PDF页数的实现方法
2016/07/21 PHP
php使用glob函数遍历文件和目录详解
2016/09/23 PHP
浅谈PHP中pack、unpack的详细用法
2018/03/12 PHP
PHP实现的mongoDB数据库操作类完整实例
2018/04/10 PHP
PHP内部实现打乱字符串顺序函数str_shuffle的方法
2019/02/14 PHP
js的for in循环和java里foreach循环的区别分析
2015/01/28 Javascript
JS实现在线统计一个页面内鼠标点击次数的方法
2015/02/28 Javascript
JS动态改变浏览器标题的方法
2016/04/06 Javascript
在JavaScript中调用Java类和接口的方法
2016/09/07 Javascript
Centos7 中 Node.js安装简单方法
2016/11/02 Javascript
JavaScript实现图片懒加载(Lazyload)
2016/11/28 Javascript
js省市区级联查询(插件版&amp;无插件版)
2017/03/21 Javascript
详解如何使用Node.js编写命令工具——以vue-cli为例
2017/06/29 Javascript
js中apply与call简单用法详解
2017/11/06 Javascript
详解vue-cli+element-ui树形表格(多级表格折腾小计)
2019/04/17 Javascript
微信小程序全局变量GLOBALDATA的定义和调用过程解析
2019/09/23 Javascript
使用JS监听键盘按下事件(keydown event)
2019/11/07 Javascript
vue 基于abstract 路由模式 实现页面内嵌的示例代码
2020/12/14 Vue.js
[03:55]2014DOTA2国际邀请赛 Fnatic经理采访赢DK在情理之中
2014/07/10 DOTA
Python的Tornado框架异步编程入门实例
2015/04/24 Python
Python使用lxml模块和Requests模块抓取HTML页面的教程
2016/05/16 Python
浅谈python为什么不需要三目运算符和switch
2016/06/17 Python
django的分页器Paginator 从django中导入类
2019/07/25 Python
宝拉珍选官方旗舰店:2%水杨酸精华液,收缩毛孔粗大和祛痘
2018/07/01 全球购物
几道PHP面试题
2013/04/14 面试题
如何利用cmp命令比较文件
2013/09/23 面试题
致百米运动员广播稿
2014/01/29 职场文书
党支部书记岗位责任制
2014/02/11 职场文书
小学生元旦感言
2014/02/26 职场文书
2014年开学第一课活动方案
2014/03/06 职场文书
幼儿教师寄语集锦
2014/04/03 职场文书
结婚通知短信大全
2015/04/17 职场文书