Java基数排序

                     Java基数排序

import java.util.*;
public class radixSort {
  static int a[] = { 421, 240, 35, 532, 305, 430, 124};
  public static void main(String args[]) {
    sort(a);
    for(int i:a)  System.out.println(i);
  }
  public static void sort(int[] array) {
    int max = array[0];// 首先找出最大值,从而确定排序的趟数
    for (int i = 1; i < array.length; i++) {
      if (array[i] > max) {
        max = array[i];
      }
    }
    int time = 0;// 判断位数
    while (max > 0) {
      max /= 10;
      time++;
    }
    List<ArrayList> queue = new ArrayList<ArrayList>();
	for (int i = 0; i < 10; i++) {// 建立10个队列
	  ArrayList<Integer> queue1 = new ArrayList<Integer>();
	  queue.add(queue1);
	}
	for (int i = 0; i < time; i++) {// 进行time次分配和收集
	  for (int j = 0; j < array.length; j++) {// 分配数组元素       
   int x = array[j] % (int) Math.pow(10, i + 1)/ (int) Math.pow(10, i);
                                             // 得到数字的第time+1位数
	    ArrayList<Integer> queue2 = queue.get(x);
	    queue2.add(array[j]);
	    queue.set(x, queue2);
          }
	  int count = 0;// 元素计数器
	  for (int k = 0; k < 10; k++) {// 收集队列元素
	    while (queue.get(k).size() > 0) {
	      ArrayList<Integer> queue3 = queue.get(k);
	      array[count] = queue3.get(0);
	      queue3.remove(0);
	      count++;
	    }
	  }
        }
    }
}


好的,关于 Java 基数排序,我可以给你一些简单的介绍。 Java 基数排序是一种非比较排序算法,它通过将待排序元素按照位数切割成不同的数字,然后按照每个位数分别比较。具体来说,它将所有待比较数值统一为同样的数位长度,数位较短的数前面补零,然后从最低位开始,依次进行一次排序,这样从最低位排序一直到最高位排序完成后,数列就变成一个有序序列。 Java 基数排序的时间复杂度为 O(d(n+r)),其中 d 是数字位数,n 是待排序元素个数,r 是基数。虽然时间复杂度比较高,但是它的空间复杂度比较低,是一种稳定的排序算法。 下面是 Java 基数排序的代码实现: ``` public static void radixSort(int[] arr) { if (arr == null || arr.length < 2) { return; } int max = Integer.MIN_VALUE; for (int i = 0; i < arr.length; i++) { max = Math.max(max, arr[i]); } int maxDigit = 0; while (max != 0) { max /= 10; maxDigit++; } int mod = 10, div = 1; List<List<Integer>> bucketList = new ArrayList<>(); for (int i = 0; i < 10; i++) { bucketList.add(new ArrayList<>()); } for (int i = 0; i < maxDigit; i++, mod *= 10, div *= 10) { for (int j = 0; j < arr.length; j++) { int num = (arr[j] % mod) / div; bucketList.get(num).add(arr[j]); } int index = 0; for (int j = 0; j < bucketList.size(); j++) { List<Integer> bucket = bucketList.get(j); for (int k = 0; k < bucket.size(); k++) { arr[index++] = bucket.get(k); } bucket.clear(); } } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值