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

基数排序 RadixSort

基数排序是一种非比较型整数排序算法,其原理是将整数按位数切割成不同的数字,然后按每个位数分别比较。由于整数也可以表达字符串(比如名字或日期)和特定格式的浮点数,所以基数排序也不是只能使用于整数 .

动态演示 :

分析 :

这里给个视频 : 基础算法-219-排序算法-基数排序2_哔哩哔哩_bilibili

案例代码 :

    public static void main(String[] args) {String[] s = new String[]{"123", "125", "151", "167", "142", "152"};//字符串数组 , 字符串长度RadixSort(s, 3);}public static void RadixSort(String[] arr, int length) {List<List<String>> list = new ArrayList<>(10);//创建桶for (int i = 0; i < 10; i++) {list.add(new ArrayList<>());}for (int j = length - 1; j >= 0; j--) {//根据位添加到桶里for (String s : arr) {list.get(s.charAt(j) - '0').add(s);}//重新排序int n = 0;for (List<String> strings : list) {for (String string : strings) {arr[n++] = string;}strings.clear();}System.out.println(Arrays.toString(arr));}}

代码 : (处理数字)

    public static void RadixSort(String[] arr, int length) {List<List<String>> list = new ArrayList<>(10);//创建桶for (int i = 0; i < 10; i++) {list.add(new ArrayList<>());}for (int j = length - 1; j >= 0; j--) {//根据位添加到桶里for (String s : arr) {list.get(s.charAt(j) - '0').add(s);}//重新排序int n = 0;for (List<String> strings : list) {for (String string : strings) {arr[n++] = string;}strings.clear();}}

代码 : (处理多种字符)

    public static void RadixSort(String[] arr, int length) {List<List<String>> list = new ArrayList<>(128);//创建桶for (int i = 0; i < 128; i++) {list.add(new ArrayList<>());}for (int j = length - 1; j >= 0; j--) {//根据位添加到桶里for (String s : arr) {list.get(s.charAt(j)).add(s);}//重新排序int n = 0;for (List<String> strings : list) {for (String string : strings) {arr[n++] = string;}strings.clear();}}

http://www.lryc.cn/news/270840.html

相关文章:

  • Maven下载和安装的详细教程
  • 申请虚拟VISA卡Fomepay教程
  • java常见面试题:什么是装箱和拆箱?装箱和拆箱有哪些应用场景
  • 【map】【滑动窗口】【字典树】C++算法:最长合法子字符串的长度
  • 机器学习部分相关概念
  • Apache DolphinScheduler 3.1.9 版本发布:提升系统的稳定性和性能
  • go-carbon v2.3.1 发布,轻量级、语义化、对开发者友好的 Golang 时间处理库
  • R_handbook_作图专题
  • 关于Python里xlwings库对Excel表格的操作(二十五)
  • 2024 年软件工程将如何发展
  • 【Git】git基础
  • Linux中账号和权限管理
  • Resnet BatchNormalization 迁移学习
  • Unity检测地面坡度丨人物上坡检测
  • SASS循环
  • Java超高精度无线定位技术--UWB (超宽带)人员定位系统源码
  • 系列十一、解压文件到指定目录
  • PHP Swoole Client
  • 《QDebug 2023年12月》
  • sklearn 中matplotlib编制图表
  • 【Docker-Dev】Mac M2 搭建docker的redis环境
  • docker +gitee+ jenkins +maven项目 (一)
  • IDEA 开发中常用的快捷键
  • Ubuntu Desktop 死机处理
  • Hermite矩阵
  • HTML 实操试题(二)
  • MongoDB 面试题
  • LeetCode 1154. 一年中的第几天:2023年最后一道每日一题
  • 《深入理解JAVA虚拟机笔记》OutOfMemoryError 异常
  • R306指纹识别模块指令系统