力扣 LeetCode 347. 前K个高频元素(Day5:栈与队列)

解题思路:

小根堆统计前K个高频元素

注意:

PriorityQueue中需要自定义排序规则

java 复制代码
class Solution {
    public int[] topKFrequent(int[] nums, int k) {
        PriorityQueue<int[]> pq = new PriorityQueue<>((x,y)->x[1]-y[1]);
        Map<Integer,Integer> map=new HashMap<>();
        for(int num:nums){
            map.put(num,map.getOrDefault(num,0)+1);
        }

        for(Map.Entry<Integer,Integer> entry:map.entrySet()){
            if(pq.size()<k) pq.add(new int[]{entry.getKey(),entry.getValue()});
            else{
                if(entry.getValue()>pq.peek()[1]){
                    pq.poll();
                    pq.add(new int[]{entry.getKey(),entry.getValue()});

                }
            }
        }
        
        int[] res=new int[k];
        for(int i=0;i<k;i++){
            res[i]=pq.poll()[0];
        }
        return res;
    }
}
相关推荐
剑挑星河月7 小时前
763.划分字母区间
数据结构·算法·leetcode
小辉同志7 小时前
74. 搜索二维矩阵
c++·leetcode·矩阵·二分查找
programhelp_7 小时前
Snowflake OA 2026 面经|3道高频真题拆解 + 速通攻略
经验分享·算法·面试·职场和发展
圣保罗的大教堂7 小时前
leetcode 3740. 三个相等元素之间的最小距离 I 简单
leetcode
Duang7 小时前
AI 真能自己写出整个 Windows 系统吗?我做了一场无监督实验
算法·设计模式·架构
少许极端7 小时前
算法奇妙屋(四十五)-CCPC备战之旅-1
java·开发语言·算法
无小道7 小时前
算法——找规律
算法·规律
圣保罗的大教堂8 小时前
leetcode 2069. 模拟行走机器人 II 中等
leetcode
地平线开发者8 小时前
目标检测的 Anchor-Free 和 NMS 到底是什么?
算法·自动驾驶
北顾笙9808 小时前
day24-数据结构力扣
数据结构·算法·leetcode