深入了解基数排序:原理、性能分析与 Java 实现

news/2025/2/11 6:02:04/

基数排序(Radix Sort)是一种非比较性排序算法,它根据元素的每个位上的值来进行排序。基数排序适用于整数或字符串等数据类型的排序。本文将详细介绍基数排序的原理、性能分析及java实现。

radixsort.jpg

基数排序原理

基数排序的基本原理是按照低位先排序,然后收集;再按照高位排序,再收集;以此类推,直到最高位。这样从最低位排序一直到最高位排序完成后,数列就变成一个有序序列。步骤如下:

  1. 从最低位开始,依次进行一次稳定的计数排序(或桶排序),根据当前位的值将元素分配到不同的桶中。

  2. 每一轮排序根据当前位的值进行桶排序,保证稳定性。

  3. 重复以上步骤直到最高位排序完成。

排序图解:
radixsort620460b3e17507e4.png

Java代码实现

以下是使用 Java 实现基数排序的示例代码:

public class Test {public static void main(String[] args) {int[] arr = new int[]{122,38,3738,333,63,436,2};System.out.println("原始数组:"+ Arrays.toString(arr));radixSort(arr);System.out.println("排序后的数组:"+ Arrays.toString(arr));}//基基数排序(Radix Sort)public static void radixSort(int[] arr) {//数组为空或者只有一个元素是返回if(arr == null || arr.length < 2){return;}//获取数组中的最大值int maxVal = Arrays.stream(arr).max().getAsInt();//计算最大值的位数int numDig  = String.valueOf(maxVal).length();//数组长度int len = arr.length;//位数计数值int dig = 1;//计算每个位数上的数字的被除数int dividend = 1;// 用于存储每个桶中元素的出现次数int[] order = new int[10];// 用于存储每个桶中的数据int[][] tempArr = new int[10][len];//循环每个位数进行桶排序while (dig <= numDig){//将数组中的数据按i位的数据放入桶中for(int i = 0; i < len; i++){//计算当前位数的值int index =  (arr[i] / dividend ) % 10  ;tempArr[index][order[index]] = arr[i];//当前位数的桶计数order[index]++;}//给元素中返回数据的下标int l = 0;//将按当前位数进行过桶排序的数据放回到源数组中for (int j = 0; j < order.length; j++){//当前桶中有数据才进行操作if(order[j] > 0){for(int k = 0; k < order[j];k++){arr[l++] = tempArr[j][k];}//将计数数组的值设置为0,方便下一位计数order[j] = 0;}}System.out.println("第"+dig+"位排序后的数组:"+ Arrays.toString(arr));//位数加1,下次进行下一位的排序dig++;//被除数乘以10,方便计算下一位数的值的计算dividend *= 10;}}}

输出结果为:

原始数组:[122, 38, 3738, 333, 63, 436, 2]
第1位排序后的数组:[122, 2, 333, 63, 436, 38, 3738]
第2位排序后的数组:[2, 122, 333, 436, 38, 3738, 63]
第3位排序后的数组:[2, 38, 63, 122, 333, 436, 3738]
第4位排序后的数组:[2, 38, 63, 122, 333, 436, 3738]
排序后的数组:[2, 38, 63, 122, 333, 436, 3738]

性能分析

  • 时间复杂度:基数排序的时间复杂度通常为 O ( d ∗ ( n + r ) ) O(d * (n + r)) O(d(n+r)),其中n是元素数量,d是数字位数,r是基数的大小。通常情况下,基数排序的时间复杂度为线性的,但它依赖于数据位数。如果位数很大,性能可能会受到影响。

  • 空间复杂度:基数排序的空间复杂度取决于计数排序的使用情况。在处理较大范围的数据时,空间复杂度可能会较高。

  • 稳定性:基数排序通常是稳定的。

实用场景

  • 当处理的数据是整数或字符串时,基数排序是一个理想的选择。例如,对于字符串排序,可以按照字符的ASCII码值进行排序。

  • 当数据集的位数相对较小且分布较为均匀时,基数排序可以表现出良好的性能。它不依赖于比较操作,因此在一些特定情况下可以优于基于比较的排序算法。

  • 在内存充足的情况下,基数排序可以高效地处理大量数据,但在位数非常大的情况下可能会受到内存限制的影响。

总结

综上所述,基数排序是一种高效的排序算法,特别适用于处理位数相对较小且分布较为均匀的整数或字符串。但需要注意,对于位数较大的数据集或内存受限的情况,可能需要考虑其他排序算法来满足要求。


http://www.ppmy.cn/news/1151787.html

相关文章

Python 实训教学,更便捷的学生邀请及内容分发|ModelWhale 版本更新

中秋国庆假期结束&#xff0c;ModelWhale 又迎来了新一轮的版本更新&#xff0c;让我们调整好节奏&#xff0c;一起奔赴新的旅程&#xff01; 本次更新中&#xff0c;ModelWhale 主要进行了以下功能迭代&#xff1a; 新增 一键邀请外部用户加入课程&#xff08;团队版✓&#…

深度学习环境 | Linux下安装,卸载,查看pytorch版本

一 在Linux下安装pytorch 1 进入Linux环境以后 新建一个名为pytorch的虚拟环境&#xff0c;执行以下代码&#xff1a; conda create -n pytorch python3.82 激活新建的pytorch虚拟环境&#xff0c;执行以下代码&#xff1a; conda activate pytorch # conda版本较新使用这条…

力扣刷题-字符串-左旋转字符串

[LCR 182.动态口令]-同剑指Offer58-II 某公司门禁密码使用动态口令技术。初始密码为字符串 password&#xff0c;密码更新均遵循以下步骤&#xff1a; 设定一个正整数目标值 target 将 password 前 target 个字符按原顺序移动至字符串末尾 请返回更新后的密码字符串。 示例 1&…

十四、【图章工具组】

文章目录 仿制图章图案图章 仿制图章 纺织图和章工具跟我们之前所用到的修补工具类似,需要我们先按住Alt键选住一块区域&#xff0c;然后调整它的硬度在用我们选择的区域去覆盖&#xff0c;需要注意的是&#xff0c;我们去做的时候尽量一笔覆盖我们想要遮住的区域: 图案图章…

python获取网口列表(获取网络接口列表、网口表)socket.if_nameindex()

文章目录 获取网口列表测试 获取网口列表 以下python代码将打印系统中所有存在的网络接口列表&#xff1a; import socketdef print_interfaces_list():# 打印所有的网络接口列表available_interfaces socket.if_nameindex()# 转换成字典形式 {if_index: if_name}available_…

主流大模型训练库和框架的介绍

文章目录 前言1.主流大模型框架介绍 前言 参考&#xff1a; Pytorch训练模型损失Loss为Nan或者无穷大&#xff08;INF&#xff09;原因 1.主流大模型框架介绍

《UnityShader入门精要》学习3

笛卡尔坐标系&#xff08;Cartesian Coordinate System&#xff09; 二维笛卡儿坐标系 一个二维的笛卡儿坐标系包含了两个部分的信息&#xff1a; 一个特殊的位置&#xff0c;即原点&#xff0c;它是整个坐标系的中心。两条过原点的互相垂直的矢量&#xff0c;即x轴和y轴。这…

vscode虚拟环境使用jupyter

在某虚拟环境内安装torch&#xff0c;但是ipyn文件保存后无法正常导入torch 1.conda环境下安装Jupyter等一切配置&#xff0c;进入虚拟环境 2.conda install nb_conda_kernels 3.安装完成后重新打开VSCode&#xff0c;在运行Jupyter notebook中的代码之前&#xff0c;在右上…