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字典序问题实例
Sep 26 Python
Python实现的弹球小游戏示例
Aug 01 Python
python 图像平移和旋转的实例
Jan 10 Python
浅谈PySpark SQL 相关知识介绍
Jun 14 Python
python3的数据类型及数据类型转换实例详解
Aug 20 Python
python同步两个文件夹下的内容
Aug 29 Python
浅析python,PyCharm,Anaconda三者之间的关系
Nov 27 Python
Python2与Python3的区别点整理
Dec 12 Python
python如何更新包
Jun 11 Python
Python实现像awk一样分割字符串
Sep 15 Python
Python实现定时监测网站运行状态的示例代码
Sep 30 Python
Pytorch 统计模型参数量的操作 param.numel()
May 13 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
推荐一篇入门级的Class文章
2007/03/19 PHP
php学习笔记 面向对象中[接口]与[多态性]的应用
2011/06/16 PHP
PHP使用strtotime获取上个月、下个月、本月的日期
2015/12/30 PHP
Ubuntu server 11.04安装memcache及php使用memcache来存储session的方法
2016/05/31 PHP
ThinkPHP中Widget扩展的两种写法及调用方法详解
2017/05/04 PHP
php如何获取Http请求
2020/04/30 PHP
PHP获取当前时间不准确问题解决方案
2020/08/14 PHP
学习ExtJS(一) 之基础前提
2009/10/07 Javascript
JavaScript 计算图片加载数量的代码
2011/01/01 Javascript
jquery 实现表单验证功能代码(简洁)
2012/07/03 Javascript
常见的原始JS选择器使用方法总结
2014/04/09 Javascript
解决checkbox的attr(checked)一直为undefined问题
2014/06/16 Javascript
深入理解JavaScript系列(27):设计模式之建造者模式详解
2015/03/03 Javascript
JavaScript简单遍历DOM对象所有属性的实现方法
2015/10/21 Javascript
JavaScript获取客户端IP的方法(新方法)
2016/03/11 Javascript
15个值得开发人员关注的jQuery开发技巧和心得总结【经典收藏】
2016/05/25 Javascript
JS实现的手机端精简幻灯片效果
2016/09/05 Javascript
vue ssr 实现方式(学习笔记)
2019/01/18 Javascript
Vue项目安装插件并保存
2019/01/28 Javascript
JsonServer安装及启动过程图解
2020/02/28 Javascript
[00:35]DOTA2上海特级锦标赛 MVP.Phx战队宣传片
2016/03/04 DOTA
[00:35]可解锁地面特效
2018/12/20 DOTA
[05:00]TI9战队采访 - Royal Never Give Up
2019/08/20 DOTA
Python学习之Django的管理界面代码示例
2018/02/10 Python
python 动态调用函数实例解析
2019/10/21 Python
pymysql模块的操作实例
2019/12/17 Python
Python+opencv+pyaudio实现带声音屏幕录制
2019/12/23 Python
用python3读取python2的pickle数据方式
2019/12/25 Python
Python3.6 + TensorFlow 安装配置图文教程(Windows 64 bit)
2020/02/24 Python
python语言中有算法吗
2020/06/16 Python
10种CSS3实现的loading动画,挑一个走吧?
2020/11/16 HTML / CSS
社区工作感言
2014/02/21 职场文书
小班上学期幼儿评语
2014/12/30 职场文书
秦始皇兵马俑导游词
2015/02/02 职场文书
教师辞职信范文
2015/02/28 职场文书
商务英语邮件开头问候语
2015/11/10 职场文书