今天要说的是:基数排序(又称桶排序)

关于基数排序,深海说一下自己的见解:

根据数据的(个,十,百,千,....)位数.分别排序后放入对应的"桶"中,最后有序的将"桶"中的数据依次从"桶"中取出,得出有序数组

如下文中,您有别的见解,欢迎评论指正,深海谢过诸位灵长类

 深海又要开始画图了!!! 

算法探索_基数排序算法(桶排序)_算法

 

public class RadixSort
{
public static void sort(int[] number, int d) //d表示最大的数有多少位
{
int k = 0;
int n = 1;
int m = 1; //控制键值排序依据在哪一位
int[][] temp = newint[10][number.length]; //数组的第一维表示可能的余数0-9
int[] order = newint[10]; //数组orderp[i]用来表示该位是i的数的个数
while(m <= d)
{
for(int i = 0; i < number.length; i++)
{
intlsd = ((number[i] / n) % 10);
temp[lsd][order[lsd]] = number[i];
order[lsd]++;
}
for(int i = 0; i < 10; i++)
{
if(order[i] != 0)
for(int j = 0; j < order[i]; j++)
{
number[k] = temp[i][j];
k++;
}
order[i] = 0;
}
n *= 10;
k = 0;
m++;
}
}
public static void main(String[] args)
{
int[] data =
{73, 22, 93, 43, 55, 14, 28, 65, 39, 81, 33, 100};
RadixSort.sort(data, 3);
for(int i = 0; i < data.length; i++)
{
System.out.print(data[i] + "");
}
}
}