保研复习数据结构记(9)--基数排序

  • 基数排序的过程?首先设置r个(r:每个关键字位可以对应多少取值)空队列,Q_0,Q_1,...,Q_{r-1},按照各个关键字位权重递增的次序(个、十、百),将d个元素(关键字可以被拆分成d个部分)分别做“分配”和“收集”。分配:顺序扫描各个元素,若当前处理的关键字位=x,则将元素插入Qx队尾。收集:把Q_0,Q_1,...,Q_{r-1}结点一次出队并链接。如果需要递增序列,那么在入队的时候就按照不同权重将序列由高到低入队。基数排序不是基于比较,而其他排序都是基于比较来完成。
  • 基数排序的空间复杂度是多少?O(r),因为设置了r个辅助队列。
  • 基数排序的时间复杂度是多少?O(d*(n+r)
  • 基数排序是稳定的?是稳定的
  • 基数排序的应用?可以应用于排序年月日
  • 基数排序擅长解决哪些问题?(1)数据元素的关键字可以方便的拆分为d组,且d较小(2)每组关键字的取值范围不大,即r较小(3)数据元素的个数n较大

相关推荐

  1. 复习数据结构(5)--并查集

    2024-03-13 08:44:01       22 阅读
  2. 数据结构-基数排序

    2024-03-13 08:44:01       43 阅读
  3. 数据结构,第8章:排序(复习

    2024-03-13 08:44:01       29 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-13 08:44:01       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-13 08:44:01       20 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-13 08:44:01       20 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-13 08:44:01       20 阅读

热门阅读

  1. 部署时的sql版本维护

    2024-03-13 08:44:01       22 阅读
  2. uView Collapse 折叠面板

    2024-03-13 08:44:01       25 阅读
  3. 24计算机考研调剂 | 长江大学

    2024-03-13 08:44:01       22 阅读
  4. 每天学习一个Linux命令之ifconfig

    2024-03-13 08:44:01       22 阅读
  5. 安卓kotlin面试题 101-105

    2024-03-13 08:44:01       17 阅读
  6. Android kotlin开启协程的几种方式

    2024-03-13 08:44:01       25 阅读