public class RadixSort {
public static void main(String[] args) {
int[] arr = new int[]{23,6,189,45,9,287,56,1,798,34,65,652,5};
radixSort(arr);
System.out.println(Arrays.toString(arr));
}
public static void radixSort(int[] arr){
//查找数组当中最大的数
int max = Integer.MIN_VALUE;
for (int i=0;i<arr.length;i++){
if (arr[i]>max){
max = arr[i];
}
}
//计算最大数数字是几位数的
int maxLength = (max+"").length();//将max加上空字符串,整体变为字符串,求得长度
//创建二维数组用于临时存放按位分类的数据
int[][] temp = new int[10][arr.length];
//创建数组用于存放temp相应数组当中存放数据的个数
int[] counts = new int[10];
//最大数字的长度就是基数排序遍历的次数
for (int i=0,n=1;i<maxLength;i++,n*=10){
//遍历每一个数字
for (int j=0;j<arr.length;j++){
//计算余数
int ys = arr[j]/n%10;
//根据余数将当前值存入temp中对应的数组
temp[ys][counts[ys]] = arr[j];
//记录数量
counts[ys]++;
}
//记录取出元素存放的位置
int index = 0;
//把数字取出来
for (int k=0;k<counts.length;k++){
//记录数量的数组中当前数值不为0
if (counts[k]!=0){
//循环取出元素
for (int l=0;l<counts[k];l++){
//取出元素
arr[index] = temp[k][l];
index++;
}
//把记录数组数量置为0
counts[k]=0;
}
}
}
}
}