我试图在1-100的随机数的ArrayList上实现Radix Sort。我几乎就在那里,我无法弄清楚十位排序。另外,我放了一些println语句来测试我的桶中的实际内容,并且在某些桶中有一些奇怪的数字不应该存在。
import java.util.ArrayList;
import java.util.Random;
private static ArrayList<Integer> newArrayList;
private static ArrayList<Integer>[] bucket = new ArrayList[10];
public static ArrayList<Integer> generateArray(int n){
newArrayList = new ArrayList<Integer>(n);
Random rand = new Random();
for (int i = 0; i<n; i++){
newArrayList.add(rand.nextInt(n + 1));
}
return newArrayList;
}
public static void sort(ArrayList<Integer> x){
for (int i = 0; i< 10; i++){
bucket[i] = new ArrayList<Integer>();
}
int power = 1;
for (int j = 0; j < 3; j++){
for (int k = 0; k < x.size(); k++){
bucket[(x.get(k)/power)%10].add(x.get(k));
}
x.clear();
for (int l = 0; l<10; l++){
x.addAll(bucket[l]);
}
power = power*10;
}
System.out.println(bucket[0]); //diagnostics
System.out.println(bucket[1]);
System.out.println(bucket[2]);
System.out.println(bucket[3]);
System.out.println(bucket[4]);
System.out.println(bucket[5]);
System.out.println(bucket[6]);
System.out.println(bucket[7]);
System.out.println(bucket[8]);
System.out.println(bucket[9]);
}
public static void main (String[] args)
{
ArrayList<Integer> new1 = new ArrayList<Integer>();
new1 = generateArray(100);
sort(new1);
}
}
以下是print语句的输出。
[70, 90, 100, 100, 90, 70, 30, 20, 100, 100, 3, 3, 5, 6, 6, 6, 6, 7, 7, 8, 70, 90, 90, 70, 30, 20, 3, 3, 5, 6, 6, 6, 6, 7, 7, 8, 61, 51, 81, 81, 61, 31, 71, 31, 41, 41, 11, 11, 11, 21, 71, 11, 71, 11, 11, 11, 11, 12, 13, 14, 15, 15, 16, 19, 19, 32, 42, 92, 42, 22, 22, 32, 52, 12, 82, 42, 20, 21, 22, 22, 26, 27, 28, 29, 29, 53, 3, 63, 3, 63, 13, 73, 83, 33, 83, 30, 31, 31, 32, 32, 33, 34, 36, 36, 39, 64, 84, 14, 64, 34, 54, 64, 41, 41, 42, 42, 42, 45, 46, 49, 49, 5, 15, 15, 55, 45, 65, 95, 51, 52, 53, 54, 55, 56, 59, 6, 86, 36, 56, 26, 6, 6, 16, 6, 46, 36, 76, 66, 61, 61, 63, 63, 64, 64, 64, 65, 66, 67, 68, 69, 69, 97, 87, 67, 7, 87, 27, 77, 7, 97, 70, 70, 71, 71, 71, 73, 76, 77, 78, 79, 8, 78, 98, 98, 28, 68, 81, 81, 82, 83, 83, 84, 86, 87, 87, 19, 49, 19, 49, 99, 79, 59, 69, 29, 39, 69, 29, 90, 90, 92, 95, 97, 97, 98, 98, 99]
[61, 51, 81, 81, 61, 31, 71, 31, 41, 41, 11, 11, 11, 21, 71, 11, 71, 11, 11, 11, 11, 12, 13, 14, 15, 15, 16, 19, 19, 100, 100, 100, 100]
[32, 42, 92, 42, 22, 22, 32, 52, 12, 82, 42, 20, 21, 22, 22, 26, 27, 28, 29, 29]
[53, 3, 63, 3, 63, 13, 73, 83, 33, 83, 30, 31, 31, 32, 32, 33, 34, 36, 36, 39]
[64, 84, 14, 64, 34, 54, 64, 41, 41, 42, 42, 42, 45, 46, 49, 49]
[5, 15, 15, 55, 45, 65, 95, 51, 52, 53, 54, 55, 56, 59]
[6, 86, 36, 56, 26, 6, 6, 16, 6, 46, 36, 76, 66, 61, 61, 63, 63, 64, 64, 64, 65, 66, 67, 68, 69, 69]
[97, 87, 67, 7, 87, 27, 77, 7, 97, 70, 70, 71, 71, 71, 73, 76, 77, 78, 79]
[8, 78, 98, 98, 28, 68, 81, 81, 82, 83, 83, 84, 86, 87, 87]
[19, 49, 19, 49, 99, 79, 59, 69, 29, 39, 69, 29, 90, 90, 92, 95, 97, 97, 98, 98, 99]
答案 0 :(得分:1)
你需要在循环的每次迭代中清除桶,否则上一次迭代的值仍然存在
for (int l = 0; l < 10; l++) {
x.addAll(bucket[l]);
bucket[l].clear(); //<-----
}