基数排序推导过程和最终算法

2024-04-15 12:32

本文主要是介绍基数排序推导过程和最终算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

推导过程:

package indi.tom.Algorithm.recursion.sort;import java.util.Arrays;/*** @Author Tom* @Date 2019/11/11 19:36* @Version 1.0* @Description 基数排序,空间换时间.这里列出推导过程。在RadixSortFinal中给出最终方法。*/
public class RadixSort {public static void main(String[] args) {int[] array = {53,3,542,748,14,214};radixSort(array);}//基数排序public static void radixSort(int[] array){//推导过程//第一轮//定义一个二维数组,充当桶int[][] buckets = new int[10][array.length];//定义一个数组,下标代表第几个桶,值对应该桶中的元素个数。int[] elementsCountInBucket = new int[10];//遍历数组元素,按个位数加到对应的每一个桶中for (int i = 0; i < array.length; i++) {int digitOfElement = array[i] % 10;buckets[digitOfElement][elementsCountInBucket[digitOfElement]] = array[i];elementsCountInBucket[digitOfElement] ++;}//将桶中元素重新放回原数组。int current = 0;//定义原数组的当前下标。for (int i = 0; i < buckets.length; i++) {if(elementsCountInBucket[i] > 0){for (int j = 0; j < elementsCountInBucket[i]; j++) {array[current++] = buckets[i][j];}}//将保存每个bucket元素个数的元素清零。elementsCountInBucket[i] = 0;}System.out.println(Arrays.toString(array));//第二轮//遍历数组元素,按个位数加到对应的每一个桶中for (int i = 0; i < array.length; i++) {int digitOfElement = array[i] /10 % 10;buckets[digitOfElement][elementsCountInBucket[digitOfElement]] = array[i];elementsCountInBucket[digitOfElement] ++;}//将桶中元素重新放回原数组。current = 0;//定义原数组的当前下标。for (int i = 0; i < buckets.length; i++) {if(elementsCountInBucket[i] > 0){for (int j = 0; j < elementsCountInBucket[i]; j++) {array[current++] = buckets[i][j];}}elementsCountInBucket[i] = 0;}System.out.println(Arrays.toString(array));//第三轮for (int i = 0; i < array.length; i++) {int digitOfElement = array[i] /100 % 10;buckets[digitOfElement][elementsCountInBucket[digitOfElement]] = array[i];elementsCountInBucket[digitOfElement] ++;}//将桶中元素重新放回原数组。current = 0;//定义原数组的当前下标。for (int i = 0; i < buckets.length; i++) {if(elementsCountInBucket[i] > 0){for (int j = 0; j < elementsCountInBucket[i]; j++) {array[current++] = buckets[i][j];}}elementsCountInBucket[i] = 0;}System.out.println(Arrays.toString(array));}
}

最终结果:

package indi.tom.Algorithm.recursion.sort;import java.util.Arrays;/*** @Author Tom* @Date 2019/11/11 19:36* @Version 1.0* @Description 基数排序,最终方法*/
public class RadixSortFinal {public static void main(String[] args) {int[] array = {53,3,542,748,14,214};radixSort(array);}//排序函数public static void radixSort(int[] array){//定义一个二维数组,充当桶int[][] buckets = new int[10][array.length];//定义一个数组,下标代表第几个桶,值对应该桶中的元素个数。int[] elementsCountInBucket = new int[10];//要检查的元素的某一位上的数字int digitOfElement;//找出给定数组的最大数,以便下一步算出该最大数的位数int max = array[0];for (int i = 0; i < array.length; i++) {if(max < array[i]){max = array[i];}}//算出数组中最大数有多少位数字,即是我们要做多少轮入桶,出桶的过程int numberOfDigits = (max + "").length();for (int i = 0; i < numberOfDigits; i++) {//遍历数组元素,按个位数加到对应的每一个桶中for (int j = 0; j < array.length; j++) {digitOfElement = array[j] / (int)Math.pow(10, i) % 10;buckets[digitOfElement][elementsCountInBucket[digitOfElement]] = array[j];elementsCountInBucket[digitOfElement] ++;}//将桶中元素重新放回原数组。int current = 0;//定义原数组的当前下标。for (int j = 0; j < buckets.length; j++) {if(elementsCountInBucket[j] > 0){for (int k = 0; k < elementsCountInBucket[j]; k++) {array[current++] = buckets[j][k];}}//将保存每个bucket元素个数的元素清零。elementsCountInBucket[j] = 0;}}System.out.println(Arrays.toString(array));}
}

 

 

这篇关于基数排序推导过程和最终算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/905820

相关文章

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三

Redis中Set结构使用过程与原理说明

《Redis中Set结构使用过程与原理说明》本文解析了RedisSet数据结构,涵盖其基本操作(如添加、查找)、集合运算(交并差)、底层实现(intset与hashtable自动切换机制)、典型应用场... 目录开篇:从购物车到Redis Set一、Redis Set的基本操作1.1 编程常用命令1.2 集

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

k8s中实现mysql主备过程详解

《k8s中实现mysql主备过程详解》文章讲解了在K8s中使用StatefulSet部署MySQL主备架构,包含NFS安装、storageClass配置、MySQL部署及同步检查步骤,确保主备数据一致... 目录一、k8s中实现mysql主备1.1 环境信息1.2 部署nfs-provisioner1.2.

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

linux部署NFS和autofs自动挂载实现过程

《linux部署NFS和autofs自动挂载实现过程》文章介绍了NFS(网络文件系统)和Autofs的原理与配置,NFS通过RPC实现跨系统文件共享,需配置/etc/exports和nfs.conf,... 目录(一)NFS1. 什么是NFS2.NFS守护进程3.RPC服务4. 原理5. 部署5.1安装NF

MySQL使用EXISTS检查记录是否存在的详细过程

《MySQL使用EXISTS检查记录是否存在的详细过程》EXISTS是SQL中用于检查子查询是否返回至少一条记录的运算符,它通常用于测试是否存在满足特定条件的记录,从而在主查询中进行相应操作,本文给大... 目录基本语法示例数据库和表结构1. 使用 EXISTS 在 SELECT 语句中2. 使用 EXIS

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二