排序算法之基数排序


title: 基数排序
date: 2024-7-25 14:29:53 +0800
categories:

  • 排序算法
    tags:
  • 排序
  • 算法
  • 基数排序
    description: 基数排序(radix sort)的核心思想与计数排序一致,也通过统计个数来实现排序。在此基础上,基数排序利用数字各位之间的递进关系,依次对每一位进行排序,从而得到最终的排序结果。
    math: true

基数排序

基数排序(Radix Sort)是一种非比较型整数排序算法。它通过将整数按位数分组排序,从最低有效位到最高有效位,或者从最高有效位到最低有效位,依次进行排序,从而实现最终的排序结果。

基数排序的原理

基数排序是一种稳定的排序算法,适用于整数排序。其主要思想是将整数按位数分组,从最低有效位开始,一次对每个位数进行计数排序(Counting Sort),最终得到有序数组。

两种实现方式

  1. LSD(Least Significant Digit):从最低有效位开始排序,逐步向最高有效位进行。
  2. MSD(Most Significant Digit):从最高有效位开始排序,逐步向最低有效位进行。

图示

基数排序

基数排序的步骤

  1. 确定最大位数:找到数组中最大数的位数,以确定需要进行几轮排序。
  2. 逐位排序:从最低有效位开始,对每个位进行计数排序。
  3. 合并结果:每次排序完成后,合并结果进行下一轮排序,直到所有位数排序完成。

示例

基数排序

为什么从最低位开始排序?

在连续的排序轮次中,后一轮排序会覆盖前一轮排序的结果。举例来说,如果第一轮排序结果 a < b ,而第二轮排序结果 a > b,那么第二轮的结果将取代第一轮的结果。由于数字的高位优先级高于低位,因此应该先排序低位再排序高位。

复杂度分析

相较于计数排序,基数排序适用于数值范围较大的情况,但前提是数据必须可以表示为固定位数的格式,且位数不能过大。例如,浮点数不适合使用基数排序,因为其位数 k k k 过大,可能导致时间复杂度 O ( n k ) ≫ O ( n 2 ) O(nk) \gg O(n^2) O(nk)O(n2)

  • 时间复杂度为 O ( n k ) O(nk) O(nk)、非自适应排序:设数据量为 n n n、数据为 d d d 进制、最大位数为 k k k ,则对某一位执行计数排序使用 O ( n + d ) O(n + d) O(n+d) 时间,排序所有 k k k 位使用 O ( ( n + d ) k ) O((n + d)k) O((n+d)k) 时间。通常情况下, d d d k k k 都相对较小,时间复杂度趋向 O ( n ) O(n) O(n)

  • 空间复杂度为 O ( n + k ) O(n + k) O(n+k)、非原地排序:与计数排序相同,基数排序需要借助长度为 n n n k k k 的数组 rescounter

  • 稳定排序:当计数排序稳定时,基数排序也稳定;当计数排序不稳定时,基数排序无法保证得到正确的排序结果。

时间复杂度

  • 最佳情况 O ( n k ) O(nk) O(nk)
  • 最坏情况 O ( n k ) O(nk) O(nk)
  • 平均情况 O ( n k ) O(nk) O(nk)

空间复杂度

  • 空间复杂度 O ( n + k ) O(n + k) O(n+k)

Java代码实现

对于一个 d d d 进制的数字 x x x ,要获取其第 k k k x k x_k xk ,可以使用以下计算公式:

x k = ⌊ x d k − 1 ⌋ m o d d x_k = \lfloor\frac{x}{d^{k-1}}\rfloor \bmod d xk=dk1xmodd

其中 ⌊ a ⌋ \lfloor a \rfloor a 表示对浮点数 a a a 向下取整,而 m o d d \bmod \: d modd 表示对 d d d 取模(取余)。
比如8位10进制的数据, d = 10 d = 10 d=10 k ∈ [ 1 , 8 ] k \in [1, 8] k[1,8]

此外,我们需要小幅改动计数排序代码,使之可以根据数字的第 k k k 位进行排序:

/* 获取元素 num 的第 k 位,其中 exp = 10^(k-1) */
int digit(int num, int exp) {// 传入 exp 而非 k 可以避免在此重复执行昂贵的次方计算return (num / exp) % 10;
}/* 计数排序(根据 nums 第 k 位排序) */
void countingSortDigit(int[] nums, int exp) {// 十进制的位范围为 0~9 ,因此需要长度为 10 的桶数组int[] counter = new int[10];int n = nums.length;// 统计 0~9 各数字的出现次数for (int i = 0; i < n; i++) {int d = digit(nums[i], exp); // 获取 nums[i] 第 k 位,记为 dcounter[d]++;                // 统计数字 d 的出现次数}// 求前缀和,将“出现个数”转换为“数组索引”for (int i = 1; i < 10; i++) {counter[i] += counter[i - 1];}// 倒序遍历,根据桶内统计结果,将各元素填入 resint[] res = new int[n];for (int i = n - 1; i >= 0; i--) {int d = digit(nums[i], exp);int j = counter[d] - 1; // 获取 d 在数组中的索引 jres[j] = nums[i];       // 将当前元素填入索引 jcounter[d]--;           // 将 d 的数量减 1}// 使用结果覆盖原数组 numsfor (int i = 0; i < n; i++)nums[i] = res[i];
}/* 基数排序 */
void radixSort(int[] nums) {// 获取数组的最大元素,用于判断最大位数int m = Integer.MIN_VALUE;for (int num : nums)if (num > m)m = num;// 按照从低位到高位的顺序遍历for (int exp = 1; exp <= m; exp *= 10) {// 对数组元素的第 k 位执行计数排序// k = 1 -> exp = 1// k = 2 -> exp = 10// 即 exp = 10^(k-1)countingSortDigit(nums, exp);}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/399479.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Modbus-RTU使用过程中的问题

此程序是在visual studio 2005的MFC程序中执行的&#xff0c;通过引入ModbusRTU.dll进行程序的编程&#xff0c;通过Dependency Walker工具查看ModbusRTU.dll中的静态函数如下&#xff1a; 在ModbusRTU.h文件中 MOD_API WORD RTUReadDiscreteInputs(BYTE nSlaveAddress, WORD …

旅游景区收银系统源代码

一、传统景区急需数字化升级 1.景区经营困境 景区内商户众多&#xff0c;收款方式不统一&#xff0c;收银pos五花八门&#xff0c;不清楚商户的流水情况 景区招商户入驻难&#xff0c;租金不好收取 景区合作的旅行社众多&#xff0c;无法统一管理&#xff0c;佣金高效结算 …

OLAP与OLTP:数据处理系统的两种核心架构

目录 一、什么是OLAP&#xff1f; 二、什么是OLTP&#xff1f; 三、OLAP与OLTP的主要区别 四、结论 在数据管理和分析的领域中&#xff0c;OLAP&#xff08;在线分析处理&#xff09;和OLTP&#xff08;在线事务处理&#xff09;代表了两种重要的数据处理模式。它们在功能、目标…

鸿蒙AI功能开发【卡证识别控件】场景视觉化服务

卡证识别控件 介绍 本示例展示了使用视觉类AI能力中的卡证识别能力。 本示例模拟了在应用里&#xff0c;跳转卡证识别控件&#xff0c;获取到验证结果并展示出来。 需要使用hiai引擎框架卡证识别验证接口kit.VisionKit.d.ts。 效果预览 使用说明&#xff1a; 在手机的主屏…

牛客JS题(四十)字体高亮

注释很详细&#xff0c;直接上代码 涉及知识点&#xff1a; 正则表达式逆向思路 题干&#xff1a; 我的答案 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /></head><body><input type"text&…

鸿蒙(API 12 Beta3版)【音视频解封装】 文件解析封装

开发者可以调用本模块的Native API接口&#xff0c;完成音视频解封装&#xff0c;即从比特流数据中取出音频、视频等媒体帧数据。 当前支持的数据输入类型有&#xff1a;远程连接(http协议、HLS协议)和文件描述符(fd)。 支持的解封装格式如下&#xff1a; 媒体格式封装格式码…

MoonBit 周报 Vol.53:新增高级循环语法、引入字符串插值、MoonBit AI 支持代码解释!

weekly 2024-08-05 MoonBit更新 添加了基于 Iter 和 Iter2 类型的 for .. in 循环支持&#xff1a; fn main {for x in [ 1, 2, 3 ] {println(x)}for k, v in { "x": 1, "y": 2 } {println("\{k} > \{v}")} }for 与 in 之间可以使用 1&…

国产的Kimi,很牛逼!

国内大模型现在百花齐放&#xff0c;给大家推荐一下最近我一直在用的大模型工具&#xff1a;kimi kimi很强大&#xff0c;关键还免费&#xff08;这一点太良心了&#xff01;&#xff09; 在 长文本和文件处理 方面&#xff0c;kimi做的非常好。 不仅如此&#xff0c;kimi 里…

html+css网页制作 电商品优购5个页面(无js)

htmlcss网页制作 电商品优购5个页面&#xff08;无js&#xff09; 网页作品代码简单&#xff0c;可使用任意HTML编辑软件&#xff08;如&#xff1a;Dreamweaver、HBuilder、Vscode 、Sublime 、Webstorm、Text 、Notepad 等任意html编辑软件进行运行及修改编辑等操作&#xf…

使用Sanic和SSE实现实时股票行情推送

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐&#xff1a;「storm…

电机学习-基础知识

文章目录 1 基本物理概念1.1 左手定则1.2 安培定则1.3 感应电动势 2 电机简单分类2.1 直流有刷电机2.2 步进电机2.2.1 步进电机的驱动原理1.相与线2.极性3.步进电机的驱动 2.3 无刷电机2.3.1 充磁方式2.3.2正弦波电动势与梯型电动势 3 编码器3.1 霍尔编码器3.2 光电编码器3.3 增…

软件设计之MySQL(1)

软件设计之MySQL(1) 此篇应在JavaSE之后进行学习: 路线图推荐&#xff1a; 【Java学习路线-极速版】【Java架构师技术图谱】 Navicat可以在软件管家下载 使用navicat连接mysql数据库创建数据库、表、转储sql文件&#xff0c;导入sql数据 学习内容&#xff1a; 数据库概述表、…

NOI Linux 2.0 的安装说明以及使用指南

关于 NOI Linux 2.0 NOI Linux 是 NOI 竞赛委员会基于 Ubuntu 操作系统开发的一款 Linux 桌面发行版&#xff0c;是一套免费的、专门为信息学奥林匹克竞赛选手设计的操作系统&#xff0c;是 NOI 系列赛事指定操作系统&#xff0c;适用于常见笔记本电脑和桌面电脑。 新建虚拟机…

卷大模型,还是卷应用?一次看明白

自从ChatGPT横空出世以来&#xff0c;中美之间围绕大模型的科技竞争愈演愈烈&#xff0c;也渐渐分化出两条差异化发展路线&#xff1a;一派侧重将AI能力投入应用场景&#xff0c;另一派则侧重让基础模型能力更强。于是&#xff0c;“卷应用”还是“卷大模型”成为中国许多新入场…

maven项目中pom.xml文件内容详解

一、什么是pom.xml文件&#xff1f; POM是项目对象模型&#xff08;Project Object Model&#xff09;的简称&#xff0c;它是Maven项目中的文件&#xff0c;XML格式&#xff0c;名称为 pom.xml&#xff0c;他是一个有关于maven操作的配置文件。每一个maven项目在创建时都会自动…

67、ceph

一、ceph 1.1、ceph概念 ceph是一个开源的&#xff0c;用c语言写的分布式的存储系统。存储文件数据。 /dev/sdb fdisk /dev/sdb gdisk /dev/sdb lvm 逻辑卷 可以扩容 raid 磁盘阵列 高可用 基于物理意义上的单机的存储系统。 分布式有多台物理磁盘组成一个集群&…

95% 向量资源节省,火山引擎云搜索 RAG 技术体系演进

采访嘉宾 | 火山引擎云搜索团队 鲁蕴铖、李杰辉、余炜强 编辑 | Tina InfoQ 2023 年&#xff0c;大模型惊艳了世界。2024 年&#xff0c;RAG 技术如日中天。 RAG 使得大模型能够在不更新模型参数的情况下&#xff0c;获得必要的上下文信息&#xff0c;从而减少大模型的幻觉。…

【科研笔记】中国知网高级检索与专业检索针对同一检索内容返回的结果对比

中国知网高级检索与专业检索针对同一检索内容返回的结果对比 文献检索文献差集文献检索 预检索“复杂网络”和“事故”相关主题的文献,在高级检索界面中搜寻的结果如下,期刊选择为中文核心及以上,共检索138条文献 然后以专业检索,构建检索式“ (SU=‘事故’) AND (SU=‘复…

前端学习笔记-JS篇-02

运算符 赋值运算符 对变量进行赋值的运算符。 已经学过的赋值运算符:【将等号右边的值赋予给左边&#xff0c;要求左边必须是一个容器】 其他赋值运算符: - * / % 原始写法和简化写法【其实就是java基础】 一元运算符 众多的JavaScript 的运…

BioMistral 7B: 生物医学领域的开源多语言AI模型

人工智能咨询培训老师叶梓 转载标明出处 尽管目前有许多开源的针对健康领域的大模型可供使用&#xff0c;但现有模型在数据隐私风险、模型性能以及多语言支持方面的局限性&#xff0c;限制了它们在医疗领域的应用。为了克服这些限制&#xff0c;研究者们提出了BioMistral&#…