java 基数排序(稳定排序)

package 快速排序_归并排序_二分查找_等排序;
/* 基数排序(桶子法)//稳定排序
 * 1.首先找到最大的数的位数
 * 2.根据最大位数把所有数字的高位补0,然后所有数字的长度相等
 * 3.根据最低位个位 0-9开始排序,得到新序列l
 * 4.再根据新序列l对十位开始排序,直到排序到最高位为止
 * 5.感觉类似于hash算法了
 * 
 * 数组中的最大数字的位数是多少,需要进行多少次整理
 * 
 */
public class JishuSort {
	public static void main(String args[]){
		int[] arr = {100,11,54,21,12,3,5,9,89,87,49,540,315};
	
		//int a = findMaxSize(arr);
		Sort(arr);
		for(int i=0;i<arr.length;i++){
			System.out.println(arr[i]);
			
		}
	}
	
	
	public static int findMaxSize(int[] arr){//求数组中最大数的长度
		int temp = arr[0];
		for(int i=1;i<arr.length;i++){
			if(temp<arr[i]){
				temp=arr[i];
			}
		}
		
		int len = String.valueOf(temp).length();//最大数的长度
		
		int cou=0;//最大数的长度
		while(temp>0){
			cou++;
			temp=temp/10;
		}
		
		
		return cou;
	}
	
	
	
	public static void Sort(int[] arr){
		int maxSize= findMaxSize(arr);
		
		int[][] ara = new int[10][arr.length];//表示每一位上为0-9的数字,相同的放在一起
		int[] rar = new int[10];//数组rar[i]用来表示某位是i的元素的个数
		int d=0;//总整理次数
		int k=0;//arr数组的下标
		int n=1;//
		
		
		while(d<maxSize){
			for(int i=0;i<arr.length;i++){//从个位开始进行排序 放到相应的二维数组中
				int yu = (arr[i]/n)%10;//求每个数每一位上的数字
				ara[yu][rar[yu]] = arr[i];
				rar[yu]++;
			}
			for(int i=0;i<10;i++){//把每趟整理的数值按整理后的顺序放到原数组中, 进行下次循环排序
				if(rar[i] != 0){
					for(int j=0; j<rar[i] ; j++){
						arr[k]=ara[i][j];
						k++;
					}
					rar[i]=0;//把相应位上的个数置空,下次使用
				}
			}
			k=0;
			n=n*10;
			d++;
		}
		
	}
	
}

好的,关于 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(); } } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值