24-数据结构-内部排序-基数排序

基数排序

基数排序,给关键字分成d位(组),,对每一位的情况,可能会出现的值位r(基数)个,然后分成r个队列,对每个对林进行分配耗时O(n),最后按照改位(组)情况,进行收集耗时O(r)

所以基数排序的

时间复杂度:O(d*(r+n))。

空间复杂度:O(r),创建r个队列。-口令:饿(额外空间)鬼(归并排序),炸鸡(基数排序)块

稳定性:稳定,一直按照关键字,有序排列的,相同关键字入队,相对位置不会变

适用情况:

1.每组关键字方便拆成d位(组),且d比较小。

2.每组关键字取值不大,r较小。

3.元素个数较大时,d比较大。

2.思路:

有点乱,简单来说,以整数为例子,有一个线性表,每个结点存储的数据都为三位数(关键字)。

  1. 三位数按照位数分为:个位、十位、百位(d=3),
  2. 先进行个位的情况,个位可能出现的数字为0-9,十个数字,因此r=10.
  3. 准备10个队列,每一个队列存储一个数字出现的可能性。按照个位,进行入队。这为分配
  4. 如果要求递减序列,则给个位按照递减,依次给队列从大队列到小队列,链接起来,最后收集成一个新的线性表,这叫收集
  5. 随后再根据十位的情况,重复类似的操作,最后进行完即可,
  6. 如图:

分配:

收集:

相关推荐
汀、人工智能3 小时前
[特殊字符] 第40课:二叉树最大深度
数据结构·算法·数据库架构·图论·bfs·二叉树最大深度
赫瑞4 小时前
数据结构中的排列组合 —— Java实现
java·开发语言·数据结构
大熊背4 小时前
ISP Pipeline中Lv实现方式探究之三--lv计算定点实现
数据结构·算法·自动曝光·lv·isppipeline
yuannl108 小时前
数据结构----队列的实现
数据结构
Mr_Xuhhh8 小时前
从ArrayList到LinkedList:理解链表,掌握Java集合的另一种选择
java·数据结构·链表
Ricardo-Yang10 小时前
SCNP语义分割边缘logits策略
数据结构·人工智能·python·深度学习·算法
soragui10 小时前
【Python】第 4 章:Python 数据结构实现
数据结构·windows·python
samroom11 小时前
【鸿蒙应用开发 Dev ECO Studio 5.0版本】从0到1!从无到有!最全!计算器------按钮动画、滑动退格、中缀表达式转后缀表达式、UI设计
数据结构·ui·华为·typescript·harmonyos·鸿蒙
算法鑫探11 小时前
10个数下标排序:最大值、最小值与平均值(下)
c语言·数据结构·算法·排序算法·新人首发
王老师青少年编程12 小时前
csp信奥赛c++之状压枚举
数据结构·c++·算法·csp·信奥赛·csp-s·状压枚举