【排序算法】基数排序
一:基本概念

1.1 基数排序(桶排序)介绍
-
基数排序(radix sort)属于“分配式排序”(distribution sort),又称“桶子法”(bucket sort)或bin sort,顾名思义,它是通过键值的各个位的值,将要排序的元素分配至某些“桶”中,达到排序的作用
-
基数排序法是属于稳定性的排序,基数排序法的是效率高的稳定性排序法
-
基数排序(Radix Sort)是桶排序的扩展
-
基数排序是1887年赫尔曼·何乐礼发明的。它是这样实现的:将整数按位数切割成不同的数字,然后按每个位数分别比较。
1.2 实现原理
将所有待比较数值统一为同样的数位长度,数位较短的数前面补零。然后,从最低位开始,依次进行一次排序。这样从最低位排序一直到最高位排序完成以后, 数列就变成一个有序序列。
1.3 将{53, 3, 542, 748, 14, 214} 使用基数排序, 进行升序排序
1.3.1 第1轮排序
数组的初始状态 arr = {53, 3, 542, 748, 14, 214}
(1) 将每个元素的个位数取出,然后看这个数应该放在哪个对应的桶(一个一维数组)
(2) 按照这个桶的顺序(一维数组的下标依次取出数据,放入原来数组)

1.3.2 第2轮排序
数组的第1轮排序 arr = {542, 53, 3, 14, 214, 748}
(1) 将每个元素的十位数取出,然后看这个数应该放在哪个对应的桶(一个一维数组)
(2) 按照这个桶的顺序(一维数组的下标依次取出数据,放入原来数组)

1.3.3 第3轮排序
数组的第2轮排序 arr = {3, 14, 214, 542, 748, 53}
(1) 将每个元素百位数取出,然后看这个数应该放在哪个对应的桶(一个一维数组)
(2) 按照这个桶的顺序(一维数组的下标依次取出数据,放入原来数组)

数组的第3轮排序 arr = {3, 14, 53, 214, 542, 748}
1.4 原理图

二:复杂度
2.1 时间复杂度

2.2 空间复杂度
LSD算法中,由于逐次清理 array 中数据,外层每一循环会开辟大小为 10 的桶,那么空间复杂度为:O ( k ),或者记为:O ( n + k )
三:代码实现
3.1 基数排序代码
/*** 基数排序*/
public class RadixSort {public static void main(String[] args) {//原始数组long start = System.currentTimeMillis();int[] array = new int[8000000];for (int i = 0; i < array.length; i++) {//Math.random() * 80000生成0到100的随机数array[i] = (int) (Math.random() * 80000);}//System.out.println("排序前:" + Arrays.toString(array));radixSort(array);long end = System.currentTimeMillis();System.out.println("执行时间为:" + (end - start));}/*** 基数排序方法* <p>* 说明:* 1.二维数组包含了十个一维数组* 2.为了防止数据在插入数组时,数据溢出,则每个桶的大小定义为array.length* 3.基数排序就是空间换时间的最典型的算法** @param array 需要排序的数组*/public static void radixSort(int[] array) {//先得到数组中最大数的位数//首先假定第一位数就是最大数int max = array[0];for (int i = 1; i < array.length; i++) {if (array[i] > max) {max = array[i];}}//得到最大数是几位数int maxLength = (max + "").length();//定义二维数组,表示十个桶,每个桶就是一个一维数组int[][] bucket = new int[10][array.length];//为了记录每个桶中实际存放了多少个数据(每次存放的时候,数据是不一样的),我们定义一个一维数组记录每次存放的数据个数// [0]记录的就是bucket[0]这个桶,每次放入数据的个数int[] bucketElementCounts = new int[10];//最大位数有maxLength,所以遍历maxLength次for (int i = 0, n = 1; i < maxLength; i++, n *= 10) {//第i轮排序:针对每个元素的位数进行排序,第一次是个位数,第二次是十位数,以此类推for (int j = 0; j < array.length; j++) {//取出每个元素的个位数的数值int digitOfElement = array[j] / n % 10;//放入到对应的桶中bucket[digitOfElement][bucketElementCounts[digitOfElement]] = array[j];//每添加一次,需要加一,保证每添加一次数据就会更新数量bucketElementCounts[digitOfElement]++;}//按照这个数组的顺序(一维数组的下标依次取数据,放入原来的数组)int index = 0;//遍历每一个桶,并且将同种的数据放入到原数组当中for (int k = 0; k < bucketElementCounts.length; k++) {//如果桶中有数据,我们才放入到原数组中if (bucketElementCounts[k] != 0) {//循环该桶,即第k个桶,也就是第k个一维数组for (int l = 0; l < bucketElementCounts[k]; l++) {//取出元素导入到arr中array[index] = bucket[k][l];index++;}}//第i+1轮处理后需要将每个bucketElementCounts[k]置为0bucketElementCounts[k] = 0;}//第一轮排序结束//System.out.println("第" + (i + 1) + "轮:对个位排序处理array=" + Arrays.toString(array));}//System.out.println("排序后:" + Arrays.toString(array));}
}
3.2 八百万条数据的执行时间

执行时间为:442毫秒
相关文章:
【排序算法】基数排序
一:基本概念 1.1 基数排序(桶排序)介绍 基数排序(radix sort)属于“分配式排序”(distribution sort),又称“桶子法”(bucket sort)或bin sort,顾名思义,它是…...
解释存储过程和函数的区别,以及它们在MySQL中的用途。如何创建和使用存储过程和函数?
解释存储过程和函数的区别,以及它们在MySQL中的用途。 存储过程和函数在MySQL中的区别及用途 区别: 返回值: 函数:必须有一个返回值,这可以是一个标量值或一个表。如果没有明确的RETURN语句,函数将返回N…...
【GPU驱动开发】-GPU架构简介
前言 不必害怕未知,无需恐惧犯错,做一个Creator! GPU(Graphics Processing Unit,图形处理单元)是一种专门用于处理图形和并行计算的处理器。GPU系统架构通常包括硬件和软件层面的组件。 一、总体流程 应…...
m位数问题(c++题解)
题目描述 考官只给两个整数n和m(1 < n < 8,1< m <5),要求选手从1,2,…,n中取出m个数字,组成一个m位整数,统计所有的m位整数中一共有多少个素数。 如n3,m2时,符合条件的整数有&…...
洛谷P1331海战
题目背景 在峰会期间,武装部队得处于高度戒备。警察将监视每一条大街,军队将保卫建筑物,领空将布满了 F-2003 飞机。 此外,巡洋船只和舰队将被派去保护海岸线。不幸的是,因为种种原因,国防海军部仅有很少…...
如何利用Flutter来写后端 服务端应用
前言 Flutter是谷歌推出的一款跨平台开发框架,现在属于此领域star最多的框架,其被广泛应用于构建前台界面,但或许很少人知道,他也可以写后端应用。 本文主角 flutter非常著名的getx库推出的get server jonataslaw/get_server:…...
数据页和缓存页(BufferPool)
1. 数据页(dataPage) 什么是数据页? 数据页是 MySQL 存储引擎在磁盘和内存之间传输数据的基本单位,默认大小为16KB。 数据页的结构: 表头:储存与页相关的元信息,比如,页号&#…...
LibreOJ 136. 最小瓶颈路 题解 最小生成树 倍增
题目链接:LibreOJ 136. 最小瓶颈路 题目描述: 给定一张无向图,询问两个结点之间的最小瓶颈路。u和v两个结点之间最小瓶颈路指的是u和v的每条路径中经过的最大边权的最小值。 题解: 给出结论:无向图的最小瓶颈路与其最小…...
前端学习第三天-css基础
1. CSS简介 从HTML被发明开始,样式就以各种形式存在。不同的浏览器结合它们各自的样式语言为用户提供页面效果的控制。最初的HTML只包含很少的显示属性。 随着HTML的成长,为了满足页面设计者的要求,HTML添加了很多显示功能。但是随着这些功能…...
各种使用chatgpt prompts技巧
1,利用chatgpt生成照片 1.1,从现在起, 当你想发送一张照片时,请使用 Markdown ,并且 不要有反斜线, 不要用代码块。使用 Unsplash API (https://source.unsplash.com/1280x720/? < PUT YOUR QUERY HERE >)。如果你明白了,请回复“明白” 1.2,开始提问生成指定场景照…...
基于单片机的企业指纹考勤系统设计
摘要: 考勤系统是企业人力资源管理的重要依据,传统的考勤系统不能保证准确性,也存在地域局限,不能满足一些跨区域集团公司的考勤要求。文章以单片机技术以及生物特征识别技术为基础,分析企业单片机智能化指纹考勤系统的设计思路,从硬件设备的选型和配置、软件系统的开发、…...
JUC(java.util.concuurrent)的常见类介绍
Java 并发包(java.util.concurrent,简称 JUC)提供了一系列的工具和框架,用于简化并发编程。以下是 JUC 包中常见类的介绍: Callable: Callable 接口是 Java 提供的一个带返回值的任务接口,类似于…...
【中科院计算所】WSDM 2024冠军方案:基于大模型进行多文档问答
作者:李一鸣 张兆 中科院计算所 会话式多文档问答旨在根据检索到的文档以及上下文对话来回答特定问题。 在本文中,我们介绍了 WSDM Cup 2024 中“对话式多文档 QA”挑战赛的获胜方法,该方法利用了大型语言模型 (LLM) 卓越的自然语言理解和生…...
Android提供了多种方式来打开特定文件夹中的视频
使用 MediaStore获取指定文件夹的视频,更优化方法: import android.content.ContentResolver; import android.content.ContentValues; import android.content.Context; import android.net.Uri; import android.os.Build; import android.os.Environme…...
基于django的购物商城系统
摘要 本文介绍了基于Django框架开发的购物商城系统。随着电子商务的兴起,购物商城系统成为了许多企业和个人创业者的首选。Django作为一个高效、稳定且易于扩展的Python web框架,为开发者提供了便捷的开发环境和丰富的功能模块,使得开发购物商…...
Swagger3 使用详解
Swagger3 使用详解 一、简介1 引入依赖2 开启注解3 增加一个测试接口4 启动服务报错1.5 重新启动6 打开地址:http://localhost:8093/swagger-ui/index.html 二、Swagger的注解1.注解Api和ApiOperation2.注解ApiModel和ApiModelProperty3.注解ApiImplicitParams和Api…...
JVM 第二部分-2(堆,方法区)
4.堆 堆 一个Java程序(main方法)对应一个jvm实例,一个jvm实例只有一个堆空间堆是jvm启动的时候就被创建,大小也确定了。大小可以用参数设置。堆是jvm管理的一块最大的内存空间 核心区域,是垃圾回收的重点区域堆可以位…...
蓝桥杯Java B组历年真题(2013年-2019年)
一、2013年真题 1、世纪末的星期 使用日期类判断就行,这里使用LocalDate,也可以使用Calendar类 答案 2099 使用LocalDate import java.time.LocalDate; import java.time.format.DateTimeFormatter; // 1:无需package // 2: 类名必须Main, 不可修改p…...
你是谁,便会遇见谁
就会进什么样的圈子。努力提升自己,才是提升阶层最可靠的方法。 在人生的舞台上,每一个人都是自己人生的主角。而在这个旅程中,我们会遇见各种各样的人,进入不同的社交圈子。正如一句古训所说:“你是谁,便…...
Linux/Centos 部署静态IP,解决无法访问目标主机、Destination Host Unreachable、无法ping通互联网的问题
Linux/Centos 部署IP,解决无法访问目标主机、Destination Host Unreachable、无法ping通互联网的问题 Linux/Centos 部署静态IP查物理机/自身电脑的IP设置VMware上的虚拟网络编辑器设置网卡IP,激活至此就可访问百度了 Linux/Centos 部署静态IP 需要注意…...
IDEC PF3S-HSC1输入模块
IDEC PF3S-HSC1 输入模块该设备属于 IDEC FA-3S系列中的高速功能模块,常见于PLC控制系统架构中,主要用于高速信号采集与输入处理,在运动控制与自动化生产线中应用较多。属于FA-3S系列PLC扩展模块,用于高速输入信号处理。可接收高速…...
LCL型三相并网变流器输出阻抗建模与稳定性分析(1)
1. LCL滤波器在并网变流器中的关键作用 我第一次接触LCL型三相并网变流器时,最头疼的就是这个看似简单的滤波器。LCL滤波器由两个电感和一个电容组成,结构上比传统的L型或LC型滤波器复杂不少。但正是这种结构,让它能在降低电感用量的同时&…...
终极指南:3步掌握Sabaki围棋软件的完整使用技巧
终极指南:3步掌握Sabaki围棋软件的完整使用技巧 【免费下载链接】Sabaki An elegant Go board and SGF editor for a more civilized age. 项目地址: https://gitcode.com/gh_mirrors/sa/Sabaki Sabaki是一款优雅的围棋棋盘软件和SGF编辑器,专为追…...
3步完成黑苹果配置工具:OpCore Simplify快速搭建macOS系统
3步完成黑苹果配置工具:OpCore Simplify快速搭建macOS系统 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 还在为复杂的OpenCore配置而烦恼…...
编程实战:苹果与虫子的数学博弈——从基础条件判断到算法优化
1. 从生活场景理解苹果与虫子问题 想象你有一筐新鲜的红苹果,放在院子里忘记盖盖子。过了一晚上,你发现有几只虫子正在啃食这些苹果。这时候你可能会想:经过这一夜的啃食,筐里还能剩下多少完整的苹果呢?这就是经典的&q…...
Tabula:从PDF数据囚笼到结构化自由的革命性解放工具
Tabula:从PDF数据囚笼到结构化自由的革命性解放工具 【免费下载链接】tabula Tabula is a tool for liberating data tables trapped inside PDF files 项目地址: https://gitcode.com/gh_mirrors/ta/tabula 在信息爆炸的时代,PDF文档已成为数据交…...
TsubakiTranslator:Galgame实时翻译完整指南与终极方案
TsubakiTranslator:Galgame实时翻译完整指南与终极方案 【免费下载链接】TsubakiTranslator 一款Galgame文本翻译工具,支持Textractor/剪切板/OCR翻译 项目地址: https://gitcode.com/gh_mirrors/ts/TsubakiTranslator 还在为语言障碍而无法畅玩心…...
用STM32F407的FSMC总线给FPGA当外挂RAM?一个实战项目带你打通软硬件
STM32与FPGA的FSMC总线实战:打造高性能异构内存扩展方案 在嵌入式系统开发中,内存资源常常成为性能瓶颈。当STM32需要处理大规模数据时,内部SRAM可能捉襟见肘。本文将展示如何利用STM32F407的FSMC总线,将FPGA内部RAM无缝扩展为MCU…...
OpCore Simplify终极指南:5分钟搞定Hackintosh EFI配置,小白也能轻松上手
OpCore Simplify终极指南:5分钟搞定Hackintosh EFI配置,小白也能轻松上手 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 还在…...
告别臃肿控制中心:AlienFX Tools如何用500KB实现Alienware设备的完全掌控
告别臃肿控制中心:AlienFX Tools如何用500KB实现Alienware设备的完全掌控 【免费下载链接】alienfx-tools Alienware systems lights, fans, and power control tools and apps 项目地址: https://gitcode.com/gh_mirrors/al/alienfx-tools 你是否曾经因为Al…...
