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++;
		}
		
	}
	
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章