Python实现基数排序——队列结构 python序列排序
off999 2024-12-26 15:55 40 浏览 0 评论
美国人口普查工作从8年缩短到6个星期的关键是使用了如下“穿孔卡片制表机”,而制表机的核心则是采用“基数排序”,该排列利用的是队列先进先出的特点,不使用比较排序。
现在小明手上有15张纸牌,每张牌上有一个数字。他首先从左到右依次抽出,以纸牌个位数为准分发,个位数相同的纸牌放在同一列上。先抽出的纸牌放在前面,后抽出的放在后面。
然后按照从左到右,从上到下的顺序,小明收回了所有的牌,效果如下所示。
第二次接龙:从左到右依次抽出,以纸牌十位数为准分发,个位数相同的纸牌放在同一列上。先抽出的纸牌放在前面,后抽出的放在后面。效果如下所示。
然后再次按照从左到右从上到下的顺序收回所有的牌,效果如下。
第三次接龙:从左到右依次抽出,以纸牌百位数为准分发,个位数相同的纸牌放在同一列上。先抽出的纸牌放在前面,后抽出的放在后面。
再次按照从左到右从上到下的顺序收回所有的牌,效果如下。
小明经过3轮发牌、收牌,现在所有的牌已经按照从小到大的顺序排列好了。思考:为什么是3轮不是5轮呢?如果最大的数字是5位,需要经过多少轮收发实现排序?
以上算法通过Python实现如下。
# 抽象队列的特征建立队列类,定义三个方法函数:进队、出队、判断是否为空
class Queue:
def __init__(self): #类的构造函数,这里使用列表存储队列元素
self.items=[]
def enQueue(self,item): #进队的方法函数
self.items.append(item) #使用列表的append方法实现添加元素
def deQueue(self): #出队的方法函数
return self.items.pop(0) #使用列表的pop方法实现删除元素
def isEmpty(self): #判断队列是否为空的方法函数
return self.items==[] #比较当前队列和空列表,返回True或False
# 定义基数排序函数
def rs(al):
mq = Queue() #创建一个队列类的实例mq
rq = [Queue() for i in range(10)] #建立列表rq,存储10个元素,均为队列类型
for i in al: #把列表al中的元素逐一读入mq中
mq.enQueue(i) #使用进队方法读入所有元素
k = len(str(max(al))) #找出al中最大值的长度,比如845长度为3,为了
求数值长度需要把数值类型转换成字符串型
for i in range(1, k + 1): #重复k轮发牌、收牌,也就是根据需要排序列表中
#最大数值的长度确定收发牌的轮数
distribute(mq, rq, i) #调用发牌函数
gather(mq, rq) #调用收牌函数
al.clear() #清空无序列表al
while not mq.isEmpty(): #当队列mq不为空
al.append(mq.deQueue()) #mq元素逐个出队添加到al列表中
# 发牌函数
def distribute(mq, rq, i):
while not mq.isEmpty(): #当mq队列不空
a = mq.deQueue() #mq元素逐个出队
#把mq队列元素按第i位分发到rq列表的第i队列
m = a % (10 ** i) // (10 ** (i - 1))
#这里不好理解,首先参数i是排序函数中确定的第几轮,还记得吧第一轮是按个位数为准发牌,第二轮
是十位数,第三轮是百位数,通过公式除以10的i次方求余,再整出10的i-1次方,可以取出该元素的
第i位。
#把mq队列出队的元素a添加到rq列表的第m个队列中
rq[m].enQueue(a)
# 收牌函数
def gather(mq, rq):
for i in rq: #逐个取出rq列表中的元素,也就是10个队列元素
while not i.isEmpty(): #当列表中的元素不为空,也就是该队列不为空
a = i.deQueue() #把该队列中的元素出队
mq.enQueue(a) #把出队的元素放到mq对列中
#主程序
al = [109, 378, 28, 5, 10, 7, 21, 845, 62, 582, 91, 336, 2, 68, 32]
#以上为待排序列表al
print("原始数据:",al) #输出原始列表
rs(al) #调用基数排序函数对al列表排序
print("排序后的数据:",al) #输出排序以后的列表al输出结果如下
原始数据: [109, 378, 28, 5, 10, 7, 21, 845, 62, 582, 91, 336, 2, 68, 32]
排序后的数据: [2, 5, 7, 10, 21, 28, 32, 62, 68, 91, 109, 336, 378, 582, 845]
相关推荐
- windows如何进入启动项(怎么进入启动选项)
-
方法步骤如下:1.点击应用在Windows设置界面点击应用选项进入。2.选择启动在左侧分类中选择启动选项。3.点击开关点击软件后方的开关即可启动或关闭开机启动项。1、在Window的文件资...
- win11下载安装
-
一、允许安装软件1、首先点击左下角的开始按键,然后点击“settings”进入设置。2、然后点击设置中的“应用”选项。3、在点击左侧任务栏中的“应用和功能”。4、点击下拉栏,然后选择其中的“任何来源”...
- win7支持的最高配置(win7支持的最高配置是多少)
-
答案是支持win7的最高配置应该是i99900k加b365主板。 不过这套配置市面上价格偏高。这种机器比同等酷睿13代处理器的价格还要高至少一千元以上。而且就性能而言要超过i99900...
- 指令引用的内存不能为read(指令引用的0x0000000内存.该内存不能为read)
-
出现“指令引用内存不能为read”的错误可能有多种原因,包括软件冲突、驱动问题、内存质量问题等。以下是一些可能的解决方案:1.检查是否有软件冲突:尝试关闭可能冲突的软件,例如杀毒软件、优化软件等。2...
- hp1010打印机驱动程序(hp deskjet1010打印机驱动)
-
1.把光盘到电脑里然后打开光盘找到“setup.exe”双击运行。2.这里点击“不用了,谢谢,我喜欢CD安装”;下载的驱动也点这个。3.到这个一步有6个软件需要安装,不用点选直接下一步即可。4.同意服...
- 电脑黑屏怎么关机(电脑黑屏怎么关机不会伤硬盘)
-
开机按F8不动到高级选项出现在松手,选“最近一次的正确配置”回车修复,还不行按F8进入安全模式还原一下系统或重装系统(如果开机没反应,放一下电,重新插拔一下硬件,如果总是开不了机就检修一下去)。如果是...
- 应用程序无法启动0xc0000005
-
4、设备主板故障也会导致无信号,建议联系专业的维修人员上门检修。5、设备显卡手指边与手指边插槽接触不良,清理一下显卡的金手指边,重新插回去,重新固定住即可。应用程序错误0xc0000005解决方法如下...
- 移动硬盘分区方法详解(移动硬盘分区步骤)
-
1、进入管理页面将新买的移动硬盘插入计算机的USB接口,右击此电脑后选择管理。2、选择压缩卷在页面里选择“磁盘管理”,右击移动硬盘,选择“压缩卷”。3、输入压缩空间的大小输入压缩空间的大小,点击右下角...
- windows7副本不是正版影响使用吗
-
会经常弹出提示和安全警告,如果我们安装了一个非正版的windows系统,就会经常弹出此windows副本不是正版的提示,那么此windows副本不是正版有什么影响呢,其实除了视觉外,功能也会有影响。w...
-
- 100个有效qq号以及密码2025(2021最新qq号和密码大全)
-
有关QQ登记全国之最的数据目前并没有最新数据更新,最新的该项数据是截止于2019年12月的数据,接下来为大家带来QQ等级全国第一的用户的有关数据,仅供大家娱乐之用:截止2019年12月,全国qq等级第一名的名字叫做“小风波”,QQ等级高达1...
-
2026-01-13 05:51 off999
- 怎么更新ios版本(怎么更新ios版本15.0)
-
苹果系统升级到指定版本的方法:下载安装【爱思助手】,打开软件后用数据线连接iPhone和电脑。等待自动安装驱动,软件显示iPhone信息后点击左侧【下载固件】。在顶部选择手机型号,将固件类型改为【可刷...
- 免费安装电脑系统软件(免费安装电脑系统软件哪个好)
-
应该是可以的只要你舍得出钱一半来说就算是笔记本换系统去电脑城就行了不会超过50块还能给你把驱动全部打好为什么非要去苏宁装呢?朋友,你好:如果在买后一年以内,属于保修范围,装系统不收费,...
- 网络适配器消失了(空腹血糖6.0,总感觉口渴怎么办)
-
网络适配器不见了原因一:未安装网卡驱动 如果电脑的系统驱动安装包中无合适的驱动文件,导致网卡驱动未能安装,自己又不知道网卡的型号,可以先从其他地方复制一个网卡万能驱动来进行安装。电脑能够上网后,再下...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
