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 相关文章推荐
用pywin32实现windows模拟鼠标及键盘动作
Apr 22 Python
Python脚本实现网卡流量监控
Feb 14 Python
10种检测Python程序运行时间、CPU和内存占用的方法
Apr 01 Python
Python实现简单的HttpServer服务器示例
Sep 25 Python
Python使用numpy实现BP神经网络
Mar 10 Python
python opencv实现图像边缘检测
Apr 29 Python
python进程和线程用法知识点总结
May 28 Python
tensorflow求导和梯度计算实例
Jan 23 Python
Python sorted排序方法如何实现
Mar 31 Python
Python 炫技操作之合并字典的七种方法
Apr 10 Python
Python实现自动签到脚本功能
Aug 20 Python
python 实现aes256加密
Nov 27 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
实用函数7
2007/11/08 PHP
解析php中两种缩放图片的函数,为图片添加水印
2013/06/14 PHP
jquery+css+ul模拟列表菜单具体实现思路
2013/04/15 Javascript
js中事件的处理与浏览器对象示例介绍
2013/11/29 Javascript
js中split函数的使用方法说明
2013/12/26 Javascript
jQuery ajax serialize() 方法使用示例
2014/11/02 Javascript
js读取并解析JSON类型数据的方法
2015/11/14 Javascript
基于JavaScript实现购物车功能
2017/02/07 Javascript
微信小程序 template模板详解及实例代码
2017/03/09 Javascript
vue.js如何更改默认端口号8080为指定端口的方法
2017/07/14 Javascript
vue源码解析之事件机制原理
2018/04/21 Javascript
JavaScript实现淘宝京东6位数字支付密码效果
2018/08/18 Javascript
vue上传图片到oss的方法示例(图片带有删除功能)
2018/09/27 Javascript
layui+SSM的数据表的增删改实例(利用弹框添加、修改)
2019/09/27 Javascript
利用JS如何获取form表单数据
2019/12/19 Javascript
Vue简单封装axios之解决post请求后端接收不到参数问题
2020/02/16 Javascript
详解element-ui动态限定的日期范围选择器代码片段
2020/07/03 Javascript
Python中针对函数处理的特殊方法
2014/03/06 Python
linux安装python修改默认python版本方法
2019/03/31 Python
对pyqt5中QTabWidget的相关操作详解
2019/06/21 Python
Python+Kepler.gl轻松制作酷炫路径动画的实现示例
2020/06/02 Python
.img/.hdr格式转.nii格式的操作
2020/07/01 Python
纯CSS3实现的阴影效果
2014/12/24 HTML / CSS
英国著名音像制品和图书游戏购物网站:Zavvi
2016/08/04 全球购物
.NET常见笔试题集
2012/12/01 面试题
平民服装店创业计划书
2014/01/17 职场文书
中层干部竞聘演讲稿
2014/05/15 职场文书
绿色环保口号
2014/06/12 职场文书
暑期实践个人总结
2015/03/06 职场文书
先进个人自荐书
2015/03/06 职场文书
情侣之间的道歉短信
2015/05/12 职场文书
交流会主持词
2015/07/02 职场文书
经典格言警句:没有热忱,世间便无进步
2019/11/13 职场文书
详解Laravel制作API接口
2021/05/31 PHP
python生成可执行exe控制Microsip自动填写号码并拨打功能
2021/06/21 Python
十大动画制作软件,Adobe产品上榜两款,第一是行业标准软件
2022/03/18 杂记