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

武汉网站开发网站手机助手

武汉网站开发网站,手机助手,国外 网站 模板,网站本地环境搭建教程基数排序详解及代码示例 基数排序原理 基数排序通过处理每一位数字进行排序,分为 LSD(最低位优先) 和 MSD(最高位优先) 两种方式。核心步骤: 确定最大值:计算数组中最大数的位数。逐位排序&am…

基数排序详解及代码示例

在这里插入图片描述


基数排序原理

基数排序通过处理每一位数字进行排序,分为 LSD(最低位优先)MSD(最高位优先) 两种方式。核心步骤:

  1. 确定最大值:计算数组中最大数的位数。
  2. 逐位排序:对每一位数字使用稳定排序(如计数排序)。

1. 标准LSD基数排序(处理正整数)

代码示例
public class RadixSort {public static void radixSort(int[] arr) {if (arr == null || arr.length == 0) return;int max = Arrays.stream(arr).max().getAsInt();for (int exp = 1; max / exp > 0; exp *= 10) {countSort(arr, exp);}}private static void countSort(int[] arr, int exp) {int[] output = new int[arr.length];int[] count = new int[10]; // 0-9Arrays.fill(count, 0);// 统计当前位数字的出现次数for (int value : arr) {count[(value / exp) % 10]++;}// 累加计数for (int i = 1; i < 10; i++) {count[i] += count[i - 1];}// 反向填充输出数组(保证稳定性)for (int i = arr.length - 1; i >= 0; i--) {int index = (arr[i] / exp) % 10;output[count[index] - 1] = arr[i];count[index]--;}// 替换原数组System.arraycopy(output, 0, arr, 0, arr.length);}public static void main(String[] args) {int[] arr = {170, 45, 75, 90, 802, 24, 2, 66};radixSort(arr);System.out.println(Arrays.toString(arr)); // [2, 24, 45, 66, 75, 90, 170, 802]}
}

2. 处理负数的LSD变体

代码示例

通过偏移将负数转换为正数后再排序:

public static void radixSortWithNegative(int[] arr) {if (arr == null || arr.length == 0) return;int min = Arrays.stream(arr).min().getAsInt();if (min < 0) {// 将所有数偏移到非负区间for (int i = 0; i < arr.length; i++) {arr[i] += -min;}}int max = Arrays.stream(arr).max().getAsInt();for (int exp = 1; max / exp > 0; exp *= 10) {countSort(arr, exp);}// 恢复原始值if (min < 0) {for (int i = 0; i < arr.length; i++) {arr[i] += min;}}
}

3. 基数为16的基数排序(十六进制)

代码示例
public static void radixSortBase16(int[] arr) {int max = Arrays.stream(arr).max().getAsInt();for (int exp = 1; max / exp > 0; exp *= 16) {countSortBase16(arr, exp);}
}private static void countSortBase16(int[] arr, int exp) {int[] output = new int[arr.length];int[] count = new int[16]; // 0-15Arrays.fill(count, 0);for (int value : arr) {int digit = (value / exp) % 16;count[digit]++;}for (int i = 1; i < 16; i++) {count[i] += count[i - 1];}for (int i = arr.length - 1; i >= 0; i--) {int digit = (arr[i] / exp) % 16;output[count[digit] - 1] = arr[i];count[digit]--;}System.arraycopy(output, 0, arr, 0, arr.length);
}

4. MSD基数排序(递归实现)

代码示例
public static void msdRadixSort(int[] arr) {msdSort(arr, 0, arr.length - 1, 1); // 从最低位开始(假设初始位权为1)
}private static void msdSort(int[] arr, int low, int high, int exp) {if (low >= high) return;// 使用计数排序处理当前位int[] count = new int[10];for (int i = low; i <= high; i++) {count[(arr[i] / exp) % 10]++;}// 累加计数并移动元素for (int i = 1; i < 10; i++) {count[i] += count[i - 1];}int[] temp = new int[arr.length];for (int i = high; i >= low; i--) {int digit = (arr[i] / exp) % 10;temp[count[digit] - 1] = arr[i];count[digit]--;}// 回填到原数组for (int i = low; i <= high; i++) {arr[i] = temp[i];}// 递归处理高位for (int i = 0; i < 10; i++) {if (count[i] > 0) {msdSort(arr, low, low + count[i] - 1, exp * 10);low += count[i];}}
}

变体对比表格

变体名称差异描述时间复杂度空间复杂度稳定性
标准LSD处理正整数,从最低位到最高位排序O(nk)O(n + k)稳定
负数LSD变体处理负数,通过偏移转换为正数O(nk)O(n + k)稳定
基数为16的变体每位基数为16,适用于十六进制O(nk)O(n + 16)稳定
MSD基数排序从最高位开始,递归处理各桶O(nk)O(n + k)稳定

关键说明

  • 时间复杂度O(nk),其中 n 是元素数量,k 是位数。
  • 空间复杂度:通常为 O(n + k),因需要额外的计数数组和临时数组。
  • 稳定性:所有变体均使用计数排序作为中间步骤,因此稳定性保持。
http://www.dtcms.com/wzjs/464368.html

相关文章:

  • 怎么做企业网站仿站关键词智能调词工具
  • 资讯网站 怎样 增强用户粘度外贸营销网站建设介绍
  • 日本做攻略国内交通网站百度识图网页版在线使用
  • 做电气设计有哪些好的网站武汉seo网络优化公司
  • 国家企业信用信息公示系统官网河北佛山网站优化服务
  • 360网站页面的工具栏怎么做免费建站的平台
  • php 网站源代码best网络推广平台
  • 可以做宣传海报的网站百度关键词多少钱一个月
  • 杭州百度做网站多少钱直通车关键词优化
  • php网站建设方案平面设计培训费用一般是多少
  • 浙江高端建设网站个人小白如何做手游代理
  • 网站建设中 什么意思网络营销推广与策划
  • 上地网站制作重庆电子商务网站seo
  • 自定义网站建站公司搜索排名优化
  • 微网站运营搜索大全浏览器
  • vue金融网站推广圳seo公司
  • 做期货的网站新手如何做网上销售
  • 中铁建设门户网登录赵伟长沙靠谱seo优化价格
  • 如何联系网站域名注册多少钱
  • 网站制作加我推广点击器
  • 北京做网站建设价格谷歌sem
  • 阿里云虚拟主机配置wordpressseo博客写作
  • 软件工程课程设计结构优化设计
  • jsp做的网站难吗网站怎么做收录
  • 建设电影播放网站谷歌搜索引擎免费入口 台湾
  • 手机网站 jsp南京seo顾问
  • 做网站有必要?汕头网站设计
  • 阿里云做电脑网站外贸seo网站建设
  • 个人网页案例关键词营销优化
  • 手游平台合肥网站推广优化