【LeetCode热题100】【堆】前 K 个高频元素

题目链接:347. 前 K 个高频元素 - 力扣(LeetCode)

要找出前K个出现频率最多的元素,可以先用哈希表存储每个元素出现的次数,然后建立一个容量为K的小顶堆,遍历哈希表找到更高频的元素入堆进行堆调整,最后堆里的元素就是前K个出现次数最多的元素

手写一个堆,就在答案容器基础上建堆,注意比较需要用哈希表比较

复制代码
class Solution {
public:
    vector<int> ans;
    int heapSize;
    unordered_map<int, int> hash;

    void adjustHeap(int root) {
        int left = 2 * root + 1;
        int right = left + 1;
        int next = root;
        if (left < heapSize && hash[ans[left]] < hash[ans[next]])
            next = left;
        if (right < heapSize && hash[ans[right]] < hash[ans[next]])
            next = right;
        if (next != root) {
            swap(ans[next], ans[root]);
            adjustHeap(next);
        }
    }

    void buildHeap() {
        for (int i = heapSize / 2 - 1; i >= 0; --i)
            adjustHeap(i);
    }

    vector<int> topKFrequent(vector<int> &nums, int k) {
        this->heapSize = k;
        for (auto &num: nums)
            hash[num]++;
        auto &&start = hash.begin();
        while (k--) {
            ans.push_back(start->first);
            ++start;
        }
        buildHeap();
        while (start != hash.end()) {
            if (start->second > hash[ans[0]]) {
                ans[0] = start->first;
                adjustHeap(0);
            }
            ++start;
        }
        return ans;
    }
};
相关推荐
纪元A梦21 分钟前
贪心算法应用:线性规划贪心舍入问题详解
java·算法·贪心算法
swan4161 小时前
2025GDCPC广东省赛游记(附赛时代码)
c++·算法·acm·icpc·算法竞赛
白熊1882 小时前
【机器学习基础】机器学习入门核心算法:Mini-Batch K-Means算法
算法·机器学习·batch
算AI2 小时前
REOBench:地球观测基础模型的鲁棒性评估
人工智能·算法
qk_antares3 小时前
【在线判题系统】By 流火
后端·leetcode
龙卷风04053 小时前
LLM+YOLO 植物病害识别技术实现流程
人工智能·算法
代码老y4 小时前
C语言进阶知识:深入探索编程的奥秘
c语言·开发语言·数据结构·算法
csdn_aspnet5 小时前
C++ 检查一条线是否与圆接触或相交(Check if a line touches or intersects a circle)
c++·算法
Java实践笔记5 小时前
40亿QQ号,只有1G内存,怎么存储和去重?
算法·面试·腾讯
Musennn5 小时前
leetcode93.复原IP地址:回溯算法中段控制与前导零处理的深度解析
java·数据结构·算法·leetcode