不基于比较的排序:基数排序

本篇只是讨论桶排序的具体实现,想了解更多算法内容可以在我的博客里搜,建议大家看看这篇排序算法总结:排序算法总结_鱼跃鹰飞的博客-CSDN博客

 桶排序的原理:

代码:sort1是一个比较二逼的实现方式浪费空间,sort2是一个正式的方法 

package sort;import java.util.Arrays;
import java.util.LinkedList;
import java.util.Queue;public class RadixSort {public static void radixSort(int[] arr) {int maxBit = getMaxBit(arr);sort2(arr, 0, arr.length - 1, maxBit);}/*** 具体的基数排序过程* @param arr 排序原始数组* @param start 要排序范围开始下标* @param end 要排序范围结束下标* @param maxBit*/public static void sort(int[] arr, int start, int end, int maxBit) {final int bucketSize = 10;//先copy一份数据,注意这里的第三个参数要+1,因为是左闭右开int[] copy = Arrays.copyOfRange(arr, start, end+1);//创建一个Queue数组,长度为10作为桶Queue<Integer>[] queues = new LinkedList[bucketSize];for(int i = 0; i < bucketSize; i++) {queues[i] = new LinkedList();}for(int digit = 0; digit < maxBit; digit ++) {for(int i = start; i <= end; i ++) {int bucketNum = digit == 0? copy[i]%10 : (copy[i]/(digit*10))%10;//如果是个位的话,直接模10,10位的话,除以digit*10。。。digit*100queues[bucketNum].offer(copy[i]);}//每一次把所有的数放完之后,从桶中倒出,先进去先倒出来(队列实现)int curIndex = 0;for (int i = start; i <= end; i++) {//从0到9挨个取出每个桶里的数据,依次放入copy数组中//这就是从桶里倒数据的过程for (Queue<Integer> queue : queues) {while (!queue.isEmpty()) {copy[curIndex ++]  = queue.poll();}}}}//把排完序的数组复制到原来的数组,如果这个方法是有返回值的,也可以直接返回copyfor(int i = 0; i < copy.length;i++) {arr[i] = copy[i];}}/*** 基数排序的省空间的解法* @param arr 原始数组* @param start 开始下标* @param end 结束下标* @param maxDigit*/public static void sort2(int[] arr, int start, int end, int maxDigit) {final int radixCount = 10;//创建一个辅助数组用于中间过程的转换,长度为区间长度int[] help = new int[end - start + 1];//如果最高位是maxDigit,那从0到maxDigit-1依次进行每一轮的入桶和出桶过程for(int digit = 0; digit < maxDigit; digit ++) {//统计数组,作为桶使用int[] countArr = new int[radixCount];//每一轮的入桶操作,countArr[i]代表当前位是i的有多少个数for(int i = start; i <= end; i++) {int digitNum = getDigitNum(arr[i], digit);countArr[digitNum] ++;}//把countArr改造为前缀和//这个循环结束了countArr[i]代表当前位小于等于i的有多少个(i这个数最后的下标是countArr[i]-1)for(int i = 0; i < countArr.length; i++) {countArr[i] = i == 0? countArr[i] : countArr[i] + countArr[i-1];}//根据前缀和数组计算当前数字要放的位置for(int i = help.length - 1; i >= 0; i --) {//取当前位的数int digitNum = getDigitNum(arr[i], digit);//辅助数组中的countArr[i]代表当前位小于等于i的有多少个,那等于i的最后一个数应该放置在countArr[i]-1位置//放完之后等于i的最后没有放元素的还有countArr[i]-1个help[--countArr[digitNum]] = arr[i];}//每一轮拷贝回原数组,方便下次循环用for(int i = start; i < end;i++) {arr[i] = help[i];}}}public static int getDigitNum(int num, int digit) {if(digit == 0) return num % 10;if(num < Math.pow(10, digit)) {return 0;}int digitNum = num;while(digit > 0) {digitNum = (digitNum / 10);digit --;}return digitNum%10;}public static int getMaxBit(int[] arr) {int maxBit = 0;for(int i = 0; i < arr.length; i++) {int curBit = 0;int val = arr[i];while(val != 0) {curBit ++;val = val/10;}maxBit = Math.max(maxBit, curBit);}return maxBit;}//判断两个数组每个位置的数是否相等public static boolean isEqualsArray(int[] arr1, int[] arr2) {if((arr1 == null && arr2 == null) || (arr1 == arr2)) return true;if(arr1 == null || arr2 == null || arr1.length != arr2.length)  return false;for(int i = 0; i < arr1.length; i++) {if(arr1[i] != arr2[i]) {return false;}}return true;}public static void main(String[] args) {int[] arr = {103, 9, 13, 17, 25, 27};int[] arr2 = {103, 9, 13, 17, 25, 27};int maxBit = getMaxBit(arr);System.out.println(maxBit);boolean isEquals = isEqualsArray(arr, arr2);System.out.println(isEquals);radixSort(arr);printArr(arr);/*int digitNum = getDigitNum(3020,1);System.out.println(digitNum);*/}public static void printArr(int[] arr) {for(int i = 0; i < arr.length; i++) {System.out.print(arr[i] + " ");}}
}

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

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

相关文章

day4 IO模型

IO多路复用 1.select函数 服务器&#xff1a; 客户端 poll函数 客户端&#xff1a;

DEWDROP65 DM蓝牙5.2双模热插拔PCB

键盘使用说明索引&#xff08;均为出厂默认值&#xff09; 软件支持&#xff08;驱动的详细使用帮助&#xff09;一些常见问题解答&#xff08;FAQ&#xff09;首次使用步骤蓝牙配对规则&#xff08;重要&#xff09;蓝牙和USB切换键盘默认层默认触发层0的FN键配置的功能默认功…

探索未来:元宇宙与Web3的无限可能

随着科技的奇迹般发展&#xff0c;互联网已经成为了我们生活的不可分割的一部分。然而&#xff0c;尽管它的便利性和普及性带来了巨大的影响&#xff0c;但我们仍然面临着传统互联网体验的诸多限制。 购物需要不断在实体店与电商平台间切换&#xff0c;教育依然受制于时间与地…

设备数字化平台的优势和应用价值

在现代工业领域&#xff0c;设备的高效管理和维护对于企业的运营和竞争力至关重要。而设备管理系统作为一个强大的工具&#xff0c;可以极大地提升设备管理和维护的效率&#xff0c;从而实现生产效益的最大化。本文将探讨设备数字化平台的优势和应用价值。 设备数字化平台是一款…

蓝牙耳机运动耳机哪个好、好用的运动蓝牙耳机推荐

如今的蓝牙耳机已经成为手机的最佳伴侣&#xff0c;也是运动爱好者的必备装备。然而&#xff0c;在众多蓝牙耳机中做出选择可能会让人感到困惑。其实&#xff0c;在选购运动蓝牙耳机时需要注意的事项还挺多的&#xff0c;比如舒适度、稳定性和音质等多个方面,逐一对照这些要点来…

MySQL数据库基础语法

一&#xff0c;数据库操作 数据库中不区分大小写&#xff01;&#xff01;&#xff01; 1.1 显示数据库 show databases ; 如图&#xff1a; 1.2 创建数据库 create database [ if not exists ]数据库名 ; 如图&#xff1a; 1.3 使用数据库 use 数据库名 &#xff1b; 如图&a…

Vue3 Axios网络请求简单应用

cd 到项目 安装Axios&#xff1a;cnpm install --save axios post传递参数 需要安装querystring 用于转换参数格式&#xff1a;cnpm install --save querystring 运行示例&#xff1a; 后台接口&#xff1a; GetTestData.java package com.csdnts.api;import java.io.IOExce…

力扣 279. 完全平方数

题目来源&#xff1a;https://leetcode.cn/problems/perfect-squares/description/ C题解&#xff08;来源代码随想录&#xff09;&#xff1a; 动规五部曲分析如下&#xff1a; 确定dp数组&#xff08;dp table&#xff09;以及下标的含义。dp[j]&#xff1a;和为j的完全平方…

【C++11】智能指针

文章目录 一.为什么要有智能指针二.内存泄漏1. 什么是内存泄漏&#xff0c;内存泄漏的危害2. 内存泄漏分类3. 检测内存泄漏4.如何避免内存泄漏 三.智能指针的原理与使用1. RAII2. auto_ptr 四.常用的智能指针1. unique_ptr2. shared_ptr3. 循环引用4. weak_ptr5. 定制删除器 五…

静态时序分析与时序约束

一、时序分析的基本概念 1. 时钟 理性的时钟模型是一个占空比为50%且周期固定的方波&#xff1a; 实际电路中输入给FPGA的晶振时钟信号是正弦波&#xff1a; 2. 时钟抖动 Clock Jitter&#xff0c;时钟抖动&#xff0c;相对于理想时钟沿&#xff0c;实际时钟存在不随时钟存在…

结构体和数组结合使用

1、定义结构体 struct Student {int num;char name[32]; }; 2、结构体数组定义 #include<iostream> using namespace std;struct Student {int num;char name[32]; }; int main() {//结构体变量复制方式2struct Student arr[2] { {1,"张三"}, {2,"李四…

【Java学习】System.Console使用

背景 在自学《Java核心技术卷1》的过程中看到了对System.Console的介绍&#xff0c;编写下列测试代码&#xff0c; public class ConsoleTest {public static void main(String[] args) {Console cs System.console();String name cs.readLine("AccountInfo: ");…

相互之间差异较大的15种颜色、35种颜色 | 颜色 色卡 色盘 RGB HEX十六进制

任意两个颜色之间&#xff0c;RGB的欧氏距离大于120 1: (211, 44, 31), #d32c1f 2: (205, 140, 149), #CD8C95 3: (67, 107, 173), #436bad 4: (205, 173, 0), #CDAD00 5: (4, 244, 137), #04f489 6: (254, 1, 154), #fe019a 7: (6, 71, 12), #06470c 8: (97, 222, 42), #61de…

基于springboot线上礼品商城

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容&#xff1a;毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 项目介绍…

docker通用镜像方法,程序更新时不用重新构建镜像

docker通用镜像方法&#xff0c;程序更新时不用重新构建镜像。更新可执行文件后&#xff0c;重新启动容器就可运行。 功能 1、在demo目录下添加脚本文件start.sh&#xff0c;里面执行demo.jar文件。 2、将demo目录映射到镜像下的 /workspace目录。 3、Dockerfile文件中默认…

使用路由器更改设备IP_跨网段连接PLC

在一些设备IP已经固定,但是需要采集此设备的数据,需要用到跨网段采集 1、将路由器WAN&#xff08;外网拨号口&#xff09;设置为静态IP 2、设置DMZ主机&#xff0c;把DMZ主机地址设置成跨网段的PLC地址 DMZ主机 基本信息. DMZ (Demilitarized Zone)即俗称的非军事区&#xff0…

LC-链表的中间节点(遍历)

LC-链表的中间节点&#xff08;遍历&#xff09; 链接&#xff1a;https://leetcode.cn/problems/middle-of-the-linked-list/description/ 描述&#xff1a;给你单链表的头结点 head &#xff0c;请你找出并返回链表的中间结点。 如果有两个中间结点&#xff0c;则返回第二个…

推断统计(配对样本t检验)

根据题目我们也可以看出配对样本 t 检验是用来检验两配对正态总体的均值是否存在显著差异的一种假设检验方法&#xff0c;虽然是两组数据但是其来自同一部分个体在两个时间段内的测试数据&#xff0c;是同一部份个体&#xff01; 进行配对样本 t 检验之后也是分别做出原假设和备…

2024软考系统架构设计师论文写作要点

一、写作注意事项 系统架构设计师的论文题目对于考生来说&#xff0c;是相对较难的题目。一方面&#xff0c;考生需要掌握论文题目中的系统架构设计的专业知识;另一方面&#xff0c;论文的撰写需要结合考生自身的项目经历。因此&#xff0c;如何将自己的项目经历和专业知识有机…

PAT 1079 Total Sales of Supply Chain

个人学习记录&#xff0c;代码难免不尽人意。 A supply chain is a network of retailers&#xff08;零售商&#xff09;, distributors&#xff08;经销商&#xff09;, and suppliers&#xff08;供应商&#xff09;-- everyone involved in moving a product from supplier…