天天看点

前k个高频元素前K个高频元素

前K个高频元素

给你一个整数数组 nums 和一个整数 k ,请你返回其中出现频率前 k 高的元素。你可以按 任意顺序 返回答案。

示例 1:

输入: nums = [1,1,1,2,2,3], k = 2

输出: [1,2]

class Solution{
    public int[] topKFrequent(int[]  nums, int k){
        Map<Integer, Integer> occurrences = new HashMap<Integer, Integer>();
        for(int num:nums){
           occurrences.put(num, occurrences.getOrDefault(num, 0) + 1;
        }
        PriorityQueue<int[]> queue = new PriorityQueue<int[]>(new Comparater<int[]>()
        {
           public int Compare(int[] m, int[] n){
                return m[1] - n[1];
           }
        });
        for(Map.Entry<Integer, Integer> entry: occurrences.entrySet()){
           int num = entry.getKey(), count = entry.getValue();
           if(queue.size()==k){
              if(queue.peek()[1]<count){
                 queue.poll();
                 queue.offer(new int[]{num, count});
              }else{
                  queue.offer(new int[]{num, count});
              }
           }
           int[] ret = new int[k];
           for(int i=0; i<k; ++i){
               ret[i] = queue.poll()[0];
           }
           return ret;
    }
}
           

继续阅读