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

Java - 基数排序算法介绍、应用场景和示例代码

概述

基数排序(Radix Sort)是一种非比较型整数排序算法,适用于整数或固定长度的字符串排序。它的基本思想是将待排序的元素分为多个关键字进行排序,通常从最低位(最低有效位,Least Significant Digit, LSD)到最高位(最高有效位,Most Significant Digit, MSD)逐位进行排序。

基数排序可以利用计数排序(Counting Sort)或桶排序作为子程序来实现单个位上的排序。这使得基数排序在特定场合下非常高效,能够以线性时间复杂度 O(d⋅(n+k))O(d \cdot (n + k))O(d⋅(n+k)) 完成排序,其中 ddd 是数字的位数,nnn 是数组的元素数量,kkk 是基数(例如 10 对于十进制数)。

算法步骤

  1. 确定最大位数:找出数组中最大数的位数(最大数字决定了要排序的轮数)。
  2. 逐位排序:从最低有效位(LSD)到最高有效位(MSD)逐位进行排序。
  3. 使用稳定排序算法:通常使用计数排序来保证每个位上的排序是稳定的。

应用场景

基数排序适用于需要对大规模整数数据进行排序的场合,尤其是当数值位数较小时。它常用于电话号码、身份证号等固定长度的数字或字符串排序。在不要求原地排序的情况下,基数排序可以高效地处理大规模数据集。

算法特点

  • 时间复杂度:O(d⋅(n+k))O(d \cdot (n + k))O(d⋅(n+k)),其中 ddd 是数字的位数,kkk 是基数。
  • 空间复杂度:需要额外的空间用于计数排序,因此空间复杂度为 O(n+k)O(n + k)O(n+k)。
  • 稳定性:是稳定的排序算法,因为使用稳定的子排序算法。

示例代码

下面是一个用 Java 实现的基数排序示例代码,针对整数数组:

import java.util.Arrays;public class RadixSort {// 获取数组中的最大值,用于确定最大位数private static int getMax(int[] arr) {int max = arr[0];for (int num : arr) {if (num > max) {max = num;}}return max;}// 对数组的某个位进行计数排序private static void countingSort(int[] arr, int exp) {int n = arr.length;int[] output = new int[n];int[] count = new int[10]; // 基数是10// 统计出现的次数for (int num : arr) {int index = (num / exp) % 10;count[index]++;}// 更新计数数组,计算累计计数for (int i = 1; i < 10; i++) {count[i] += count[i - 1];}// 构建输出数组for (int i = n - 1; i >= 0; i--) {int num = arr[i];int index = (num / exp) % 10;output[count[index] - 1] = num;count[index]--;}// 将排序结果复制回原数组System.arraycopy(output, 0, arr, 0, n);}// 基数排序主函数public static void radixSort(int[] arr) {int max = getMax(arr);// 从最低有效位开始排序for (int exp = 1; max / exp > 0; exp *= 10) {countingSort(arr, exp);}}public static void main(String[] args) {int[] arr = {170, 45, 75, 90, 802, 24, 2, 66};System.out.println("排序前数组:");System.out.println(Arrays.toString(arr));radixSort(arr);System.out.println("排序后数组:");System.out.println(Arrays.toString(arr));}
}

代码解析

  1. 获取最大值:通过 getMax 方法获取数组中的最大值,确定排序次数。
  2. 计数排序countingSort 方法对数组的每一位进行计数排序,参数 exp 表示当前排序的位数。
  3. 逐位排序:通过 exp 逐位递增,对每个位进行排序。
  4. 输出数组构建:在计数排序中,通过逆序遍历原数组来保证稳定性。

优缺点

  • 优点
    • 可以实现线性时间复杂度的排序,特别是在位数有限的情况下。
    • 是稳定的排序算法。
  • 缺点
    • 需要额外的空间来存储计数和输出数组。
    • 只能用于整数或固定长度的字符串排序。
    • 对于非常大的整数(位数过多)时,效率可能不如其他线性排序算法。

总结

基数排序是一种高效的非比较排序算法,在特定场合能够以线性时间完成排序。它特别适合用于对整数或固定长度的字符串进行排序。在实现过程中,通常与计数排序结合使用,以确保排序的稳定性和高效性。

相关文章:

Java - 基数排序算法介绍、应用场景和示例代码

概述 基数排序&#xff08;Radix Sort&#xff09;是一种非比较型整数排序算法&#xff0c;适用于整数或固定长度的字符串排序。它的基本思想是将待排序的元素分为多个关键字进行排序&#xff0c;通常从最低位&#xff08;最低有效位&#xff0c;Least Significant Digit, LSD…...

Django 后端架构开发:文件云存储,从本地存储到腾讯COS桶集成

⭐ Django 后端架构开发&#xff1a;文件云存储&#xff0c;从本地存储到腾讯COS桶集成 目录 ☁️ 文件云存储 - 项目使用云存储&#x1f4bb; 文件云存储 - 项目中使用本地存储&#x1f4dd; 文件云存储 - 概述和创建项目&#x1f310; 腾讯COS桶 - 概述&#x1f4da; 腾讯CO…...

【系统分析师】-综合知识-计算机网络与信息安全

1、要对消息明文进行加密传送&#xff0c;当前通常使用的加密算法是 报文认证算法&#xff1a;数字摘要 RSA 非对称加密&#xff0c;一般不用于明文 MD5 数字摘要 SHA-1 数字摘要&#xff0c;160位的消息摘要 HMAC 以一个密钥和一个消息为输入&#xff0c;生成一个消息摘要作…...

C++ | Leetcode C++题解之第363题矩形区域不超过K的最大数值和

题目&#xff1a; 题解&#xff1a; class Solution { public:int maxSumSubmatrix(vector<vector<int>> &matrix, int k) {int ans INT_MIN;int m matrix.size(), n matrix[0].size();for (int i 0; i < m; i) { // 枚举上边界vector<int> sum(…...

python动画:场景的线性变换展示

一&#xff0c;主函数 LinearTransformationScene 是 Manim 中用于展示线性变换的场景类。它通过在一幅背景和前景平面上展示向量和变换&#xff0c;帮助理解线性代数中的概念。 LinearTransformationScene(include_background_planeTrue, include_foreground_planeTrue, ba…...

HBase体系架构与环境搭建

这里写目录标题 一、常见的NoSQL数据库二、HBase的体系架构和表结构三、搭建HBasa环境1.本地模式2.伪分布模式全分布模式HA模式 一、常见的NoSQL数据库 NoSQL数据库的说明与定义 NoSQL是一种不同于关系数据库的数据库管理系统设计方式&#xff0c;是对非关系型数据库的统称。它…...

海思SD3403/SS928V100开发(16)Tsensor驱动开发

1. 前言 由于需要检测SD3403芯片内部实时温度,需要开发Tsensor传感器驱动和应用 查看手册发现SD3403内部有三个Tsensor传感器 可以参考之前我写的35系列平台Tsensor驱动开发记录 海思35系列平台Tsensor驱动开发(1)驱动编写_t sensor-CSDN博客 海思35系列平台Tsensor驱动…...

JVM类加载机制—JVM类加载过程

一、概述 代码编译后&#xff0c;就会生成JVM&#xff08;Java虚拟机&#xff09;能够识别的二进制字节流文件&#xff08;*.class&#xff09;。而JVM把Class文件中的类描述数据从文件加载到内存&#xff0c;并对数据进行校验、转换解析、初始化&#xff0c;使这些数据最终成…...

可变参数模板与包装器

抱歉&#xff1a;铁汁们&#xff0c;最近在做兼职&#xff0c;积累社会经验&#xff0c;多有拖欠&#xff0c;请多多包涵&#xff08;抱拳&#xff09; 引子&#xff1a;接上回我们讲了C11的几种新增&#xff0c;今天就来接着讲C11中比较有用的二个东西可变参数模板与包装器。…...

工业控制常用“对象“数据类型汇总(数据结构篇)

合理巧妙的数据结构会大大简化项目的编程工作量,所以任何项目前期第一步应该是设计巧妙的数据结构、封装对象属性。这样会使我们的编程快捷和高效。这篇博客作为数据类型汇总,会不间断更新。 1、普通电机轴对象 2、普通电机轴对象(详细结构变量) TYPE "udtMotorAxis&q…...

优雅处理枚举前端丢失大Long精度问题

1. 枚举-json处理&#xff08;前端 <> 后端 <> 数据库&#xff09; 前端传递 枚举code 后端响应 枚举code 表里存储 枚举code 内存处理 枚举对象 Getter AllArgsConstructor JsonFormat(shape JsonFormat.Shape.OBJECT) public enum SexEnum {MALE(0, "男&…...

【c/c++】 学习ector 容器笔记

c/c 学习ector 容器笔记 int 型的 vector 容器应该使用什么类型的索引&#xff1f; 对于 int 型的 vector 容器&#xff0c;应该使用 size_t 类型的索引。size_t 是一个无符号整数类型&#xff0c;它在标准库中广泛用于表示大小和索引。它足够大&#xff0c;可以表示任何标准…...

DN专业3D图形制作软件win/mac软件安装下载(附下载链接)

目录 一、软件概述 1.1 Adobe DN简介 1.2 Windows/Mac系统要求 Windows系统&#xff1a; Mac系统&#xff1a; 二、安装步骤 2.1 下载与解压 2.2 安装程序 2.3 启动软件 三、使用教程 3.1 界面介绍 3.2 创建和编辑3D内容 3.3 合成与渲染 四、高级技巧与注意事项 …...

VSCode搭建Hzero(SpringCloud架构)后端开发调试环境

正常情况下我们使用IDEA开发Hzero&#xff0c;但是有的公司是不允许破解或者使用IDEA的&#xff0c;此时可以使用eclipse来替代也是可以的&#xff0c;最近尝试使用VSCode来开发调试发现了一些问题其中最大的问题是Vscdoe在绝大多数情况下是不能直接运行Hzero&#xff0c;使用插…...

【C++】OJ习题(初阶)

&#x1f680;个人主页&#xff1a;奋斗的小羊 &#x1f680;所属专栏&#xff1a;C 很荣幸您能阅读我的文章&#xff0c;诚请评论指点&#xff0c;欢迎欢迎 ~ 目录 &#x1f4a5;1、字符串&#x1f4a5;1.1 字符串相加&#x1f4a5;1.2 验证回文字符串&#x1f4a5;1.3 反转…...

6.4K+ Star!一个强大的本地知识库问答系统,支持多格式文件和跨语言检索,为企业提供高效、安全的数据洞察……

https://github.com/netease-youdao/QAnything 【阅读原文】跳转Github项目 转自AIGC创想者 项目简介 QAnything 是一个基于本地知识库的问答系统&#xff0c;它能够理解和回答基于任何类型文件的问题。 QAnything支持的文件格式非常广泛&#xff0c;包括PDF、Word、PPT、XL…...

mvn编译的时候出现Perhaps you are running on a JRE rather than a JDK 解决方法

目录 1. 问题所示2. 原理分析3. 解决方法1. 问题所示 mvn编译的时候出现如下问题: [ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.13.0:compile (default-compile) on project yudao...

React原理之Fiber详解

前置文章&#xff1a; React原理之 React 整体架构解读React原理之整体渲染流程 -----读懂这一篇需要对 React 整体架构和渲染流程有大致的概念 &#x1f60a;----- 在React原理之 React 整体架构解读中&#xff0c;简单介绍了 Fiber 架构&#xff0c;也了解了 Fiber 节点的…...

远离“优越感”陷阱,拥抱美好人生

在人生的漫长旅程中,我们不断地与他人相遇、相知、相交,在各种关系中寻找温暖、支持与成长。然而,并非所有的关系都如我们所愿,有些关系甚至可能成为我们前进道路上的阻碍。正如我们所知,唯利是图者不可交,但有一种关系比索要金钱更值得警惕,那就是找你索取满足感的关系…...

Redis的线程模型

Redis作为一种基于内存的高性能键值对数据库&#xff0c;其线程模型和IO模型是实现高性能的关键因素。以下将详细探讨Redis的线程与IO模型&#xff0c;内容不少于2000字。 一、Redis的线程模型 Redis的线程模型是理解其高性能的重要基础。在Redis的发展过程中&#xff0c;其线…...

VCF 9.1 Consumption CLI 插件同步失败解决方法

一、问题现象 在 VCF 9.1 环境执行 vcf plugin sync 同步插件时&#xff0c;系统尝试下载 9.0.1 版本插件&#xff08;环境实际为 9.1&#xff09;&#xff0c;出现以下错误&#xff1a; [i] Installing plugins from plugin group vmware-vcfcli/essentials:v9.0.1 [x] Fail…...

三步解锁九大网盘高速下载:LinkSwift终极直链解析教程

三步解锁九大网盘高速下载&#xff1a;LinkSwift终极直链解析教程 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 &#xff0c;支持 百度网盘 / 阿里云盘 / 中国移动云盘 / 天翼…...

无代码物联网开发实战:WipperSnapper与Adafruit IO快速构建数据采集系统

1. 项目概述&#xff1a;当硬件开发告别代码如果你和我一样&#xff0c;对物联网项目充满热情&#xff0c;但又时常被嵌入式编程的编译、烧录、调试劝退&#xff0c;那么今天聊的这个工具&#xff0c;可能会彻底改变你的工作流。我们不再需要为读取一个按键的状态去写几行digit…...

Python小红书数据采集终极指南:xhs库完整使用教程与实战案例

Python小红书数据采集终极指南&#xff1a;xhs库完整使用教程与实战案例 【免费下载链接】xhs 基于小红书 Web 端进行的请求封装。https://reajason.github.io/xhs/ 项目地址: https://gitcode.com/gh_mirrors/xh/xhs 小红书作为国内领先的生活方式分享平台&#xff0c;…...

Midjourney V6啤酒标签设计实战:3步生成高转化率精酿包装,附可复用Prompt模板

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;Midjourney V6啤酒标签设计实战&#xff1a;3步生成高转化率精酿包装&#xff0c;附可复用Prompt模板 精准定义品牌视觉语义 Midjourney V6 对文本理解显著增强&#xff0c;需将抽象品牌调性转化为可解…...

PCB设计规范-机插定位孔设计要求

核心要求1) 机插定位孔的孔径为4mm&#xff0c;只能是机械孔&#xff0c;孔内不能沉铜。2) 第一个机插定位孔位于PCB板长边的左下角&#xff0c;机插定位孔的中心与两板的距离都等于5mm。3) 第二机插定位孔仅位于PCB板长边的右下角&#xff0c;距离长边的板边5mm&#xff0c;离…...

GPT Image 2刷屏后,AI赚钱的新门槛变了:向量引擎、deepseek v4、api和key怎么串成一个Agent工作流

GPT Image 2刷屏后&#xff0c;AI赚钱的新门槛变了&#xff1a;向量引擎、deepseek v4、api和key怎么串成一个Agent工作流最近 AI 圈有一种很奇妙的割裂感。 一边是大家刷到 GPT Image 2 的实测图&#xff0c;心里直呼&#xff1a;这也太真了吧&#xff1f;电影海报像真的&…...

Docker容器化机械臂控制:OpenClaw项目环境部署与实战

1. 项目概述&#xff1a;当机械臂遇上Docker最近在折腾一个挺有意思的项目&#xff0c;叫openclaw-in-docker。光看名字&#xff0c;很多朋友可能就猜到了&#xff0c;这是一个把开源机械臂控制项目OpenClaw给容器化的工程。简单来说&#xff0c;就是把原本可能需要在特定系统、…...

【51单片机】直流电机PWM调速实战:从驱动电路到闭环控制

1. 直流电机驱动基础与硬件选型 第一次玩直流电机时&#xff0c;我直接拿杜邦线把电机接在51单片机的IO口上&#xff0c;结果电机纹丝不动&#xff0c;还差点烧了芯片。这个教训让我明白&#xff1a;驱动电路是电机控制的第一道门槛。常见的直流电机工作电压通常在3-6V&#xf…...

Agent 工具调用链路的稳定性设计:从触发决策到异常兜底的工程实践

在构建基于 Agent 的 AI 应用时&#xff0c;工具调用链路是核心能力之一。我们曾遇到一个典型问题&#xff1a;用户提问“帮我查一下昨天北京天气”&#xff0c;Agent 判断应调用天气工具&#xff0c;但实际未执行任何操作&#xff0c;既未返回错误也未返回结果&#xff0c;前端…...