我对以下代码有三个问题:
static void funct(int[] list) {
final int N = 20;
java.util.ArrayList[] buckets = new java.util.ArrayList[N];
for(int i = 0; i< list.length; i++) {
int key = list[i];
if(buckets[key] = null)
buckets[key].add(list[i]);
}
int k = 0
for(int i = 0; i <buckets.length; i++) {
if(buckets[i] != null) {
for(int j = 0; j< buckets[i].size(); j++)
list[k++] = (Integer)buckets[i].get(j);
}
}
}
该算法有一个很大的缺点,是它最多只能处理 20 个元素并且复杂度很差吗?
代码的重点是对元素列表进行排序-将它们放入数组中,然后放入桶中,然后将它们从桶中再次放入数组中?
这是我很难过的一个,你将如何修改该方法,以便你可以传递一个包含另一个类的对象而不是整数的数组?