class Solution {
public int[] topKFrequent(int[] nums, int k) {
//使用HashMap统计每个元素出现的次数,元素为键,元素出现的频次为值
HashMap<Integer,Integer> map = new HashMap<>();
for(int num : nums){
if(map.containsKey(num)){
map.put(num,map.get(num) + 1);
}else{
map.put(num,1);
}
}
//桶排序
//将频次作为数组的下标,对于出现频次不同的数字集合,存入相应的数组下标
List<Integer>[] buckets = new ArrayList[nums.length + 1];
for(int key : map.keySet()){
//获取出现的次数作为下标
int i = map.get(key);
if(buckets[i] == null){
buckets[i] = new ArrayList();
}
buckets[i].add(key);
}
// topK用于保存 频率前K高的元素
List<Integer> topK = new ArrayList();
//倒序遍历数组获取出现顺序从大到小的排列
for(int i = buckets.length - 1;i >= 0 && topK.size() < k;i--){
if(buckets[i] == null) {
continue;
};
//如果buckets[i]的容量 小于k - topK.size(),全放到topK List中
if(buckets[i].size() <= (k - topK.size())){
topK.addAll(buckets[i]);
}else{
//容量不够了,放 0 ~ k - topK.size()个
topK.addAll(buckets[i].subList(0,k - topK.size()));
}
}
//定义结果集res,将List转为数组输出
int[] res = new int[k];
for(int i =0;i < k;i++){
res[i] = topK.get(i);
}
return res;
}
}