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进行稳定可靠的文件操作详解
Dec 31 Python
Python中的zipfile模块使用详解
Jun 25 Python
python字典键值对的添加和遍历方法
Sep 11 Python
Python标准库inspect的具体使用方法
Dec 06 Python
简单谈谈python中的lambda表达式
Jan 19 Python
python实现一个点绕另一个点旋转后的坐标
Dec 04 Python
python中format函数如何使用
Jun 22 Python
python中tkinter窗口位置\坐标\大小等实现示例
Jul 09 Python
详解基于python的图像Gabor变换及特征提取
Oct 26 Python
python sleep和wait对比总结
Feb 03 Python
Python实现老照片修复之上色小技巧
Oct 16 Python
5个pandas调用函数的方法让数据处理更加灵活自如
Apr 24 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
不错的新闻标题颜色效果
2006/12/10 Javascript
用Jquery实现可编辑表格并用AJAX提交到服务器修改数据
2009/12/27 Javascript
javascript之AJAX框架使用说明
2010/04/24 Javascript
jQuery中setTimeout的几种使用方法小结
2013/04/07 Javascript
JavaScript Ajax Json实现上下级下拉框联动效果实例代码
2013/11/23 Javascript
dreamweaver 8实现Jquery自动提示
2014/12/04 Javascript
js实现简单选项卡与自动切换效果的方法
2015/04/10 Javascript
jquery SweetAlert插件实现响应式提示框
2015/08/18 Javascript
基于jquery步骤进度条源码分享
2015/11/12 Javascript
使用jQuery在移动页面上添加按钮和给按钮添加图标
2015/12/04 Javascript
JavaScript希尔排序、快速排序、归并排序算法
2016/05/08 Javascript
解析浏览器端的AJAX缓存机制
2016/06/21 Javascript
简易的JS计算器实现代码
2016/10/18 Javascript
原生JS实现圆环拖拽效果
2017/04/07 Javascript
js自定义瀑布流布局插件
2017/05/16 Javascript
vue cli 全面解析
2018/02/28 Javascript
详解如何创建并发布一个 vue 组件
2018/11/08 Javascript
原生javascript中this几种常见用法总结
2020/02/24 Javascript
vue watch监控对象的简单方法示例
2021/01/07 Vue.js
[01:07:21]NAVI vs VG Supermajor 败者组 BO3 第二场 6.5
2018/06/06 DOTA
关于python的bottle框架跨域请求报错问题的处理方法
2017/03/19 Python
python实现几种归一化方法(Normalization Method)
2019/07/31 Python
详解numpy.meshgrid()方法使用
2019/08/01 Python
利用纯CSS3实现动态的自行车特效源码
2017/01/20 HTML / CSS
CSS3实现苹果手机解锁的字体闪亮效果示例
2021/01/05 HTML / CSS
html5 移动端视频video的android兼容(去除播放控件、全屏)
2020/03/26 HTML / CSS
美国维生素、补充剂、保健食品购物网站:Vitacost
2016/08/05 全球购物
HTC VIVE美国官网:VR虚拟现实眼镜
2018/02/13 全球购物
C语言编程练习
2012/04/02 面试题
广州御银科技股份有限公司试卷(C++)
2016/11/04 面试题
葡萄牙语专业个人求职信
2013/12/10 职场文书
企业总经理职责
2014/02/02 职场文书
公务员政审单位鉴定材料
2014/05/16 职场文书
买卖合同纠纷代理词
2015/05/25 职场文书
企业宣传语大全
2015/07/13 职场文书
MySQL慢查询的坑
2021/04/28 MySQL