算法--桶排序与基数排序
程序员文章站
2022-03-24 16:21:38
...
1、实现
public static void main(String[] args) {
int[] src = { 5,6,7,16,15,14,13,12,11,10,8,9,9 };
radixSort(src, 10, 2);
print(src);
// bucketSort(src, 3, 20);
// print(src);
}
//桶排序
public static void bucketSort(int[] data, int min, int max) {
// 缓存数组
int[] tmp = new int[data.length];
// buckets用于记录待排序元素的信息
// buckets数组定义了max-min个桶
int[] buckets = new int[max - min];
// 计算每个元素在序列出现的次数
for (int i = 0; i < data.length; i++)
//data[i] - min为相当于min的下标
buckets[data[i] - min]++;
for (int i = 1; i < max - min; i++)
//算出下标的具体位置。如果有重复的 下标会跳跃
buckets[i] = buckets[i] + buckets[i - 1];
// 将data中的元素完全复制到tmp数组中
System.arraycopy(data, 0, tmp, 0, data.length);
// 根据buckets数组中的信息将待排序列的各元素放入相应位置
for (int k = data.length - 1; k >= 0; k--) {
int buckIndex = tmp[k] - min;//相对下标
//根据相对下标得出tmp[k]的具体位置 最重要的转换
//--buckets是因为有相同的数据,下标可以减一
int index = --buckets[buckIndex];
data[index] = tmp[k];
}
}
//基数排序
public static void radixSort(int[] data, int radix, int d) {
// 缓存数组
int[] tmp = new int[data.length];
// buckets用于记录待排序元素的信息
int[] buckets = new int[radix];
for (int i = 0, rate = 1; i < d; i++) {
Arrays.fill(buckets, 0);
System.arraycopy(data, 0, tmp, 0, data.length);
for (int j = 0; j < data.length; j++) {
//获取数字rate位的数字 如123的十位 (123/10)%10 = 2
int subKey = (tmp[j] / rate) % radix;
//出现的次数
buckets[subKey]++;
}
for (int j = 1; j < radix; j++)
//计算下标
buckets[j] = buckets[j] + buckets[j - 1];
for (int m = data.length - 1; m >= 0; m--) {
int subKey = (tmp[m] / rate) % radix;
//类似桶排序
data[--buckets[subKey]] = tmp[m];
}
//进一位 再次处理
rate *= radix;
}
}
public static void print(int src[]){
for (int i = 0; i < src.length; i++) {
System.out.print(src[i] + " ");
}
System.out.println();
}
参考:
http://www.cnblogs.com/kkun/archive/2011/11/23/2260267.html
http://www.cnblogs.com/skywang12345/p/3603669.html
http://www.cnblogs.com/oumyye/p/4522467.html
http://blog.csdn.net/apei830/article/details/6596104
上一篇: 结构化数据