【写在前面】

参考文章:

https://blog.csdn.net/nrsc272420199/article/details/82691596【给出的示例图,简单易懂,但是对于没一轮循环没有讲解的很清楚】

https://www.cnblogs.com/sfencs-hcy/p/10616446.html【代码实现+思路,值得借鉴】

【正文部分】

  网上有很多关于基数排序的讲解,不过基于每个人的理解力不同,所以理解起来难易程度也有所不同。大家给出的博客、见解很多,不过我找了好久要么就是程序实现的思路,晦涩难懂,要么就是图示复杂难看(没有贬义,不是丑,是不容易看懂的意思),找了好久找到上面推荐的两篇博客,结合两个博主的例子写了这篇博客。好了,下面开始正式的讲解。

  基数排序的原理就是按照将每个元素的从低到高的顺序依次取出各位上的元素,然后每次按照取出的元素进行归类和重整。直到所有的位数都排完。简单的将就是先拆分后整合。借鉴文章1给出的例子,原始数组如下所示:

  第一趟排序,先取出各个元素的个位数字,并进行分组如下:

 
  然后按照每组中的数字添加的顺序对数据进行整合,先进先出,得到新的数组如下,第一趟排序后完成的工作为将数组按照个位数由小到大的顺序进行了排序。

  第二趟,对第一趟的结果按照十位数进行分组,结果如下:

  同样的方法,将分组后的数组按照添加的顺序分别取出,得到新的数组如下:

  第二趟排序后,数组按照十位数由小到大进行了排序,同时由于个位数已经进行了排序,因此将分组后的数组添加顺序取出时,十位数相同的较小的会排在前面,如31和38,43和49

  第三趟,对第二趟的结果按照百位数进行分组,结果如下:

  然后将分组后的数组按照索引的大小分别取出,得到新的数组如下:

  第三趟排序后完成的工作是将数组按照百位数由小到大进行了排序,同时由于个位数和十位数都已经进行了排序,所以较小的数会排在前面,这样就完成了整个数组的排序.

  由上面的过程可以知道如果最大数有n位,则需要n次(按照索引分组+按照索引大小取出数据)循环。所以程序中需要先找出最大数字和最大数字的位数。

  具体实现:

def radix_sort(s):
"""基数排序"""
i = 0 # 记录当前正在排拿一位,最低位为1
max_num = max(s) # 最大值
j = len(str(max_num)) # 记录最大值的位数
while i < j:
bucket_list =[[] for _ in range(10)] #初始化桶数组
for x in s:
bucket_list[int(x / (10**i)) % 10].append(x) # 找到位置放入桶数组
print(bucket_list)
s.clear()
for x in bucket_list: # 放回原序列
for y in x:
s.append(y)
i += 1 if __name__ == '__main__':
a = [334,5,67,345,7,345345,99,4,23,78,45,1,3453,23424]
radix_sort(a)
print(a)

输出结果:

[[], [1], [], [23, 3453], [334, 4, 23424], [5, 345, 345345, 45], [], [67, 7], [78], [99]]
[[1, 4, 5, 7], [], [23, 23424], [334], [345, 345345, 45], [3453], [67], [78], [], [99]]
[[1, 4, 5, 7, 23, 45, 67, 78, 99], [], [], [334, 345, 345345], [23424, 3453], [], [], [], [], []]
[[1, 4, 5, 7, 23, 45, 67, 78, 99, 334, 345], [], [], [23424, 3453], [], [345345], [], [], [], []]
[[1, 4, 5, 7, 23, 45, 67, 78, 99, 334, 345, 3453], [], [23424], [], [345345], [], [], [], [], []]
[[1, 4, 5, 7, 23, 45, 67, 78, 99, 334, 345, 3453, 23424], [], [], [345345], [], [], [], [], [], []]
[1, 4, 5, 7, 23, 45, 67, 78, 99, 334, 345, 3453, 23424, 345345]

  备注:这里贴出文章2中给出的参考代码,这里有一点原博主做的很好,在每一次循环的时候给了一个print函数,可以方便的看出每一轮循环中桶中的数据分布情况。

  原博主在求最大值和最大值的位数的时候用了库函数来实现,方法很好,代码看起来很简洁,不过为了更易懂,或者有时候如果有限制不让用库函数的时候,直接给出一个自定义函数求取参数,另外对响应的代码作出了注释,代码如下所示:

def radix_sort(s):
"""基数排序代码实现"""
maxNum = s[0] # 求取的最大值
for x in s:
if maxNum < x:
maxNum = x
times = 0 # 循环实现的次数
while maxNum > 0:
maxNum = maxNum//10
times = times+1 i = 0 # 记录当前正在排拿一位,最低位为0
while i < times:
bucket_list = [[] for _ in range(10)] # 初始化桶数组为十个空列表
for each in s:
bucket_list[(each // (10**i)) % 10].append(each) # 根据当前所求的位的数值大小,找到对应的位置放入桶数组
s.clear()
for x in bucket_list: # for的嵌套,从桶中取出元素放回原序列
for y in x:
s.append(y)
i += 1 if __name__ == '__main__':
a = [334,5,67,345,7,345345,99,4,23,78,45,1,3453,234]
radix_sort(a)
print(a)

  显然易见,没有了库函数的加持,代码显得很臃肿。。。。

【写在最后】

  该文章是参考上面两个博主的博客写的,也加上了自己的看法和理解,如果有没讲到位的地方,可以去原博客查看。

  博主支持原创,也尊重原创,如有侵权,联系博主删帖,转发注明出处

八大排序算法之基数排序(python实现)的更多相关文章

  1. 八大排序算法的 Python 实现

    转载: 八大排序算法的 Python 实现 本文用Python实现了插入排序.希尔排序.冒泡排序.快速排序.直接选择排序.堆排序.归并排序.基数排序. 1.插入排序 描述 插入排序的基本操作就是将一个 ...

  2. Python实现八大排序算法(转载)+ 桶排序(原创)

    插入排序 核心思想 代码实现 希尔排序 核心思想 代码实现 冒泡排序 核心思想 代码实现 快速排序 核心思想 代码实现 直接选择排序 核心思想 代码实现 堆排序 核心思想 代码实现 归并排序 核心思想 ...

  3. Python - 八大排序算法

    1.序言 本文使用Python实现了一些常用的排序方法.文章结构如下: 1.直接插入排序 2.希尔排序 3.冒泡排序 4.快速排序 5.简单选择排序 6.堆排序 7.归并排序 8.基数排序 上述所有的 ...

  4. 【Python】八大排序算法的比较

    排序是数据处理比较核心的操作,八大排序算法分别是:直接插入排序.希尔排序.简单选择排序.堆排序.冒泡排序.快速排序.归并排序.基数排序 以下是排序图解: 直接插入排序 思想 直接插入排序是一种最简单的 ...

  5. 八大排序算法总结与java实现(转)

    八大排序算法总结与Java实现 原文链接: 八大排序算法总结与java实现 - iTimeTraveler 概述 直接插入排序 希尔排序 简单选择排序 堆排序 冒泡排序 快速排序 归并排序 基数排序 ...

  6. [Data Structure & Algorithm] 八大排序算法

    排序有内部排序和外部排序之分,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部的排序记录,在排序过程中需要访问外存.我们这里说的八大排序算法均为内部排序. 下图为排序 ...

  7. 八大排序算法Java实现

    本文对常见的排序算法进行了总结. 常见排序算法如下: 直接插入排序 希尔排序 简单选择排序 堆排序 冒泡排序 快速排序 归并排序 基数排序 它们都属于内部排序,也就是只考虑数据量较小仅需要使用内存的排 ...

  8. 八大排序算法详解(动图演示 思路分析 实例代码java 复杂度分析 适用场景)

    一.分类 1.内部排序和外部排序 内部排序:待排序记录存放在计算机随机存储器中(说简单点,就是内存)进行的排序过程. 外部排序:待排序记录的数量很大,以致于内存不能一次容纳全部记录,所以在排序过程中需 ...

  9. Java八大排序算法

    Java八大排序算法: package sort; import java.util.ArrayList; import java.util.Arrays; import java.util.List ...

随机推荐

  1. 云原生 AI 前沿:Kubeflow Training Operator 统一云上 AI 训练

    分布式训练与 Kubeflow 当开发者想要讲深度学习的分布式训练搬上 Kubernetes 集群时,首先想到的往往就是 Kubeflow 社区中形形色色的 operators,如 tf-operat ...

  2. Python - pipupgrade 库

    使用 pipupgrade 可以批量更新本地包.系统包 安装库 pip install pipupgrade 批量更新 pipupgrade -V -l -y -V.--verbose 显示详细输出 ...

  3. 洛谷P1603——斯诺登的密码(字符串处理)

    https://www.luogu.org/problem/show?pid=1603#sub 题目描述 2013年X月X日,俄罗斯办理了斯诺登的护照,于是他混迹于一架开往委内瑞拉的飞机.但是,这件事 ...

  4. 迷你商城后台管理系统---------stage3项目部署测试汇总

    系统测试 在项目部署到云服务器之前,已通过本机启动springboot程序,访问localhost:8080,输入登陆的账户等一系列操作测试:功能测试.健壮性测试,系统已满足用户规定的需求. 系统部署 ...

  5. HTML基本概念及基本标签

    HTML基本概念及基本语法 1.HTML的基本概念 1.1  B/S.C/S基本概念 B/S(Browser/Server):指的是浏览器端与服务器端工作模式,优点相对节省本地存储空间,不足是需要占用 ...

  6. Jenkins操作手册 - 巨详细,一篇足矣!

    一.继续集成相关概念 1.1.什么是持续集成? 随着软件开发复杂度的不断提高,团队开发成员间如何更好的协同工作以确保软件开发的质量已经成为开发过程中不可回避的问题.尤其是近年来敏捷开发在软件领域越来越 ...

  7. Linux系列(21) - 光盘、U盘挂载

    挂载光盘 mount命令.umount命令 step-1 建立挂载点 原理:相当于建立盘符,建个目录读取光盘内容 命令:[root@localhost ~]# mkdir /mnt/cdrom/ 备注 ...

  8. struts2 使用ajax进行图片上传

    第一步:引入一个插件    jquery.form.js /*! * jQuery Form Plugin * version: 3.36.0-2013.06.16 * @requires jQuer ...

  9. 不关闭selinux下配置php+httpd访问KingbaseES

    在不关闭selinux的情况下使httpd+php+KingbaseES正常使用1.正常设置php.apache 除了正常流程外还需要在/etc/sysconfig/httpd最后追加LD_LIBRA ...

  10. HTML 网页开发、CSS 基础语法——八.HTML基本语法

    表格制作 1.表格基础 创建一个简单的表格至少有三个标签组成,分别是<table>,<tr>,<td>标签. table:表格,定义的是整个的表格大结构. tr:t ...