当前位置: 首页 > news >正文

我叫:基数排序【JAVA】

1.自我介绍

基数排序(radix sort)属于“分配式排序” (distribution sort),又称“桶子法” (bucket sort)或bin sort,它是通过键值的各个位的值,将要排序的元素分配至某些“桶”中,是‘桶排序’的扩展

2.基本思想

将所有待比较数值统一为同样的数位长度,数位较短的数前面补零。然后,从最低位开始,依次进行一次排序。这样从最低位排序一直到最高位排序完成以后,数列就变成一个有序序列。

 3.代码山

 public static void radixSort(int[] array) {//1.定义二维数组,表示十个桶//2.二维数组包含十个一维数组,防止溢出定义为array.length//3.空间换时间int[][] bucket = new int[10][array.length];//记录每个桶,实际存放多少个数据,定义一个一维数组//bucketCounts[0],就是记录bucket[0]桶的放入数据的个数int[] bucketCounts = new int[10];//得到数组中,最大数的位数int max = array[0];//假设数组中,第一个数最大for (int i = 1; i < array.length; i++) {if (array[i] > max) {max = array[i];}}//得到最大数的位数int maxLength = (max + "").length();for (int i = 0, n = 1; i < maxLength; i++, n *= 10) {//第一轮排序(每个元素的个位)for (int j = 0; j < array.length; j++) {int geWei = array[j] / n % 10;bucket[geWei][bucketCounts[geWei]] = array[j];bucketCounts[geWei]++;}//按照这个桶的顺序取//遍历每一个桶,把数据放回原数组int index = 0;for (int k = 0; k < bucketCounts.length; k++) {//如果桶中有数据,放回原数组,否则直接passif (bucketCounts[k] != 0) {//循环第k个桶for (int l = 0; l < bucketCounts[k]; l++) {//取出元素放入array中array[index] = bucket[k][l];index++;}}//第i+1轮后,每个桶置为0bucketCounts[k] = 0;}System.out.println("第"+(i+1)+"轮后:array="+Arrays.toString(array));}}

4.测试 

int[] array = new int[]{2,3,4,5,15,19,26,27,36,38,44,46,47,48,50};radixSort(array);

5.总结 

加入负数可以发现,程序直接报错

原因:桶的下表是从0开始的,加入负数,会越界 

如果有负数加入排序,就不推荐用基数排序了~~

相关文章:

我叫:基数排序【JAVA】

1.自我介绍 基数排序(radix sort)属于“分配式排序” (distribution sort)&#xff0c;又称“桶子法” (bucket sort)或bin sort,它是通过键值的各个位的值,将要排序的元素分配至某些“桶”中,是‘桶排序’的扩展 2.基本思想 将所有待比较数值统一为同样的数位长度,数位较短的数…...

ArkUI开发进阶—@Builder函数@BuilderParam装饰器的妙用与场景应用【鸿蒙专栏-05】

ArkUI开发进阶—@Builder函数@BuilderParam装饰器的妙用与场景应用 HarmonyOS,作为一款全场景分布式操作系统,为了推动更广泛的应用开发,采用了一种先进而灵活的编程语言——ArkTS。ArkTS是在TypeScript(TS)的基础上发展而来,为HarmonyOS提供了丰富的应用开发工具,使开…...

智慧城市内涝积水监测仪功能,提升城市预防功能

内涝积水监测仪不仅改变了人们应对城市内涝的老办法&#xff0c;还让智慧城市往前迈了一大步。这个监测仪是怎么做到的呢&#xff1f;就是靠它精准的数据监测和预警&#xff0c;让城市管理有了更科学高效的解决妙招。它就像有了个聪明又负责任的助手&#xff0c;让城市管理更加…...

ISCTF2023 部分wp

学一年了还在入门( web where_is_the_flag ISCTF{41631519-1c64-40f6-8dbb-27877a184e74} 圣杯战争 <?php // highlight_file(__FILE__); // error_reporting(0);class artifact{public $excalibuer;public $arrow;public function __toString(){echo "为Saber选择…...

springboot(ssm毕业生学历证明系统Java(codeLW)

springboot(ssm毕业生学历证明系统Java(code&LW) 开发语言&#xff1a;Java 框架&#xff1a;ssm/springboot vue JDK版本&#xff1a;JDK1.8&#xff08;或11&#xff09; 服务器&#xff1a;tomcat 数据库&#xff1a;mysql 5.7&#xff08;或8.0&#xff09; 数据…...

分布式锁3: zk实现分布式锁

一 zk 实现分布式锁 1.1 zk分布式操作命令 1.指令&#xff1a; ls / get /zookeeper create /aa "test" delete /aa set /aa "test1" 分布式锁实现原理与最佳实践 2..znode节点类型&#xff1a; 永…...

每日博客Day8

每日博客Day 8 每日算法 206.翻转链表 个人第一次思路&#xff1a; 其实我个人的第一个思路是比较暴力的&#xff0c;我第一遍暴力遍历链表&#xff0c;把链表的所有数值全部都保存到数组里面&#xff0c;然后翻转这个数组&#xff0c;再重复的覆盖当前的这个链表。但是这样…...

Redis-主从与哨兵架构

Jedis使用 Jedis连接代码示例&#xff1a; 1、引入依赖 <dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>2.9.0</version> </dependency> 2、访问代码 public class JedisSingleTe…...

PTA 7-3 将数组中的数逆序存放

本题要求编写程序&#xff0c;将给定的n个整数存入数组中&#xff0c;将数组中的这n个数逆序存放&#xff0c;再按顺序输出数组中的元素。 输入格式: 输入在第一行中给出一个正整数n&#xff08;1≤n≤10&#xff09;。第二行输入n个整数&#xff0c;用空格分开。 输出格式:…...

JavaScript 如何拷贝对像(Object)或者数组(Array)

目录 JavaScript数据拷贝类型 浅拷贝 深拷贝 举例&#xff1a; 浅拷贝 数组 对象 深拷贝 lodash cloneDeep使用示例 自定义深拷贝方法示例 JSON.parse() 和 JSON.stringify()使用示例 JavaScript数据拷贝类型 浅拷贝 数组可以使用Array.prototype.slice()方法 …...

nodejs669在线图书借阅管理系统vue前端

系统的设计与实现主要实现角色有管理员和用户,管理员在后台管理用户模块、用户表模块、图书借阅模块、图书归还模块、图书分类模块、token表模块、收藏表模块、书籍信息模块、图书资讯模块、留言板模块、书籍信息评论表模块、注册用户模块、配置文件模块、处罚记录模块、在线客…...

计算机网络之概述

一、概述 1.1因特网概述 定义 网络(Network)由若干结点(Node)和连接这些结点的链路(Link)组成。多个网络还可以通过路由器互连起来&#xff0c;这样就构成了一个覆盖范围更大的网络&#xff0c;即互联网&#xff08;或互连网&#xff09;因此&#xff0c;互联网是“网络的网络…...

git stash save untracked not staged

git stash save untracked not staged 如图 解决方案&#xff1a; git stash save "tag标记信息" --include-untracked或者&#xff1a; git stash save -u "tag标记信息" git stash clear清空本地暂存代码_zhangphil的博客-CSDN博客文章浏览阅读486次。…...

spring-boot集成mybatis-generator

通用 Mapper 在 1.0.0 版本的时候增加了 MyBatis Generator (以下简称 MBG) 插件&#xff0c;使用该插件可以很方便的生成实体类、Mapper 接口以及对应的 XML 文件。 下面介绍了 mybatis-generator 在 spring-boot 中的使用过程 一、引入pom依赖 <dependencies><de…...

C++中用于动态内存的new和delete操作符

文章目录 1、动态分配内存的应用2、动态分配内存与分配给普通变量的内存有什么不同?3、C 中如何分配/释放内存4、new 操作符4.1 使用new的语法4.2 初始化内存4.3 分配内存块4.4 普通数组声明 Vs 使用new4.5 如果运行时没有足够内存可用怎么办&#xff1f; 5、delete 操作符 C/…...

什么是美颜sdk?集成第三方美颜sdk的步骤

本文将深入探讨如何集成第三方美颜sdk&#xff0c;为直播平台引入更先进、更具吸引力的美颜特效。 第一步&#xff1a;选择合适的第三方美颜sdk 在开始集成美颜sdk之前&#xff0c;首要任务是选择适合自己直播平台需求的第三方美颜sdk。不同的sdk可能具有不同的特色和性能&a…...

Gogs服务搭建及软件的使用

Gogs基本操作使用&#xff1a;https://blog.51cto.com/yangxingzhen/5980346 Gitea—私有git服务器搭建教程:https://huaweicloud.csdn.net/638db200dacf622b8df8c7f1.html?spm1001.2101.3001.6650.3&utm_mediumdistribute.pc_relevant.none-task-blog-2%7Edefault%7ECTR…...

Python基础语法之学习运算符

Python基础语法之学习运算符 一、代码二、效果 一、代码 print("1 1 ", 1 1) print("1 - 1 ", 1 - 1) print("1 * 1 ", 1 * 1) print("11 / 5 ", 11 / 5) print("11 // 5 ", 11 // 5) print("9 % 5 ", 9…...

freertos任务调度机制深度分析(以RISC-V架构为例)

1、前言 本文是以RISC-V架构为例进行讲解&#xff0c;在汇编代码层面和ARM架构不一样&#xff0c;但是整体框架是一样的侧重任务调度底层机制讲解&#xff0c;讲解代码只保留了基本功能&#xff0c;可配置的功能基本都已经删除本文是以可抢占式调度机制进行讲解RISC-V架构只支持…...

深入了解Spring Boot中@Async注解的8大坑点

文章目录 1. 缺少EnableAsync注解2. 异步方法需独立3. 不同的异步方法间无法相互调用4. 返回值为void的异步方法无法捕获异常5. 外部无法直接调用带有Async注解的方法6. Async方法不适用于private方法7. 缺失异步线程池配置8. 异步方法与事务的兼容结语 &#x1f389;深入了解S…...

Go的unsafe.Pointer与uintptr:手动内存管理的风险与收益

Go语言以其简洁的内存管理模型著称&#xff0c;但标准库中的unsafe包却为开发者提供了手动操作内存的能力。unsafe.Pointer与uintptr这两个类型&#xff0c;允许绕过Go的类型安全检查&#xff0c;直接与底层内存交互。这种能力虽然强大&#xff0c;却也伴随着极高的风险。本文将…...

GZCTF动态Flag题目从开发到上架全流程:以Python Flask镜像为例

GZCTF动态Flag题目开发与部署实战指南&#xff1a;Python Flask全流程解析 在CTF竞赛生态中&#xff0c;动态Flag机制已成为现代赛题设计的黄金标准。不同于传统静态Flag容易被暴力破解或直接泄露&#xff0c;动态Flag为每个参赛队伍生成唯一标识&#xff0c;大幅提升题目安全性…...

公司网站SEO优化需要定期优化调整吗

公司网站SEO优化需要定期优化调整吗&#xff1f; 在当今数字化时代&#xff0c;公司网站的SEO优化&#xff08;搜索引擎优化&#xff09;不仅是提升网站曝光率的关键&#xff0c;更是增加客户流量和转化率的重要手段。有许多企业在SEO优化上存在疑惑&#xff0c;尤其是关于“公…...

嵌入式USB MIDI主机栈的空指针防护与实时性增强

1. USBHOST 库概述&#xff1a;面向嵌入式实时系统的 MIDI 主机协议栈增强实现USBHOST 是一个专为 ARM Cortex-M 系统&#xff08;特别是基于 mbed OS 的 STM32/NXP 平台&#xff09;设计的轻量级 USB 主机协议栈扩展模块&#xff0c;其核心目标是可靠、低延迟地支持 USB MIDI …...

Deneyap雨水传感器I²C驱动与嵌入式应用指南

1. 项目概述Deneyap Yagmur Algılama Modl (Deneyap Rain Sensor)&#xff0c;是土耳其Deneyap教育平台推出的专用雨水检测传感器模块&#xff0c;型号为M32&#xff08;MPV1.0&#xff09;&#xff0c;其核心控制器采用STMicroelectronics的STM8S003F3P6 8位微控制器。该模块…...

Chord视频理解工具实战教程:日志记录与分析过程可追溯性配置

Chord视频理解工具实战教程&#xff1a;日志记录与分析过程可追溯性配置 1. 工具概览与核心价值 Chord视频时空理解工具是一款基于Qwen2.5-VL架构开发的本地智能视频分析解决方案。这个工具专门解决视频内容深度理解的需求&#xff0c;能够对视频进行帧级特征提取和时序分析&…...

从‘亮暗模式’到‘向量夹角’:用大白话和几何直觉彻底搞懂归一化互相关(NCC)

从乐高积木到向量空间&#xff1a;用生活化类比拆解归一化互相关&#xff08;NCC&#xff09;的核心逻辑 想象你正在玩一款特殊的乐高积木游戏&#xff1a;每块积木的凸起和凹陷构成独特纹路&#xff0c;而你的任务是在一堆杂乱积木中找出与手中样本完全契合的那一块。这个看似…...

基于metaRTC的H264/H265嵌入式高清直播系统开发指南

1. 为什么选择metaRTC开发嵌入式直播系统 第一次接触metaRTC是在一个教育录播项目里&#xff0c;客户要求系统必须支持H265编码&#xff0c;还得能在ARM架构的嵌入式设备上稳定运行。当时试了好几个开源方案&#xff0c;不是编解码性能跟不上&#xff0c;就是内存占用太高。直到…...

OpCore-Simplify:黑苹果智能配置工具如何化繁为简?

OpCore-Simplify&#xff1a;黑苹果智能配置工具如何化繁为简&#xff1f; 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 为什么黑苹果配置总是让人望…...

打卡信奥刷题(3071)用C++实现信奥题 P6951 [ICPC 2018 WF] Wireless is the New Fiber

P6951 [ICPC 2018 WF] Wireless is the New Fiber 题目描述 一种新型的无限带宽无线通信刚刚通过测试&#xff0c;并被证明可以替代现有的基于光纤的通信网络&#xff0c;后者正努力跟上流量增长的步伐。你被委托决定新通信网络的布局。当前的通信网络由一组节点&#xff08;…...