【重点】【堆】347.前K个高频元素

题目

最大的K个元素 => 小根堆(类似上窄下宽的梯形)

最小的K个元素 => 大根堆(类似倒三角形)

法1:小根堆

java 复制代码
class Solution {
    public int[] topKFrequent(int[] nums, int k) {
        Map<Integer, Integer> valToCountMap = new HashMap<>();
        for (int i : nums) {
            valToCountMap.put(i, valToCountMap.getOrDefault(i, 0) + 1);
        }
        PriorityQueue<int[]> queue = new PriorityQueue<>((a, b) -> a[1] - b[1]);
        for (Map.Entry<Integer, Integer> entry : valToCountMap.entrySet()) {
            int val = entry.getKey(), count = entry.getValue();
            if (queue.size() == k) {
                if (count > queue.peek()[1]) {
                    queue.poll();
                    queue.offer(new int[]{val, count});
                }
            } else {
                queue.offer(new int[]{val, count});
            }
        }

        int[] res = new int[k];
        for (int i = 0; i < k; ++i) {
            res[i] = queue.poll()[0];
        }

        return res;
    }
}
相关推荐
azaz_plus2 天前
C++ priority_queue 堆
开发语言·c++·stl··priority_queue
DARLING Zero two♡20 天前
【初阶数据结构】森林里的树影 “堆” 光:堆
c语言·数据结构·c++··
Ronin-Lotus22 天前
程序代码篇---C/C++中的变量存储位置
c语言·c++···静态区·文字常量区·变量存储位置
Lostgreen1 个月前
堆(Heap)的原理与C++实现
数据结构·堆排序·
轩情吖1 个月前
二叉树-堆(补充)
c语言·数据结构·c++·后端·二叉树··排序
keysky2 个月前
「SPOJ2666」QTREE4 - Query on a tree IV
线段树··树链剖分
Tisfy3 个月前
LeetCode 1705.吃苹果的最大数目:贪心(优先队列) - 清晰题解
算法·leetcode·优先队列·贪心·
跳跳的向阳花3 个月前
16-02、JVM系列之:内存与垃圾回收篇(二)
jvm·内存··老年代·方法区·新生代
2401_858286114 个月前
102.【C语言】数据结构之用堆对数组排序
c语言·开发语言·数据结构·算法·
极客先躯4 个月前
高级java每日一道面试题-2024年11月24日-JVM篇-说说对象分配规则?
java·jvm···对象分配规则