LeetCode-M347-堆-前K个高频元素

题目

给定一个非空数组,返回其中出现频率前K高的元素。
示例1

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

示例2

输入:nums = [1], k = 1
输出:[1]

思路

  1. 首先,提到出现频率,就能想到,使用字典中key-value形式,当有重复关键字出现,value就加一。
  2. 其次,本题要求返回出现频率前K高的元素,即需要对value进行排序,依次输出前k个。这恰好符合堆的性质。难点在于,怎么按map中的value值排序!
  3. 本题使用hashmap统计数组中每个元素出现的个数,然后维护一个存储键值对且容量为k的优先队列,并自定义该优先队列的排序方式,实现最小堆,即最后优先队列里存储的是最大的三个值。而顶部是当前出现频率最小的元素,最后倒序出队访问即可。

解答

class Solution {
public:
    typedef pair<int, int> mypair;  //key-value
    
    struct cmp {    //自定义排序方法
        bool operator()(const mypair &left, const mypair &right) const
        {
            return left.second > right.second;
        }
    };
    
    vector<int> topKFrequent(vector<int>& nums, int k) {
        vector<int> ans(k, 0);
        unordered_map<int, int> hash;
        priority_queue<mypair, vector<mypair>, cmp> que;  //优先队列
        
        for(auto key : nums)   //统计每个元素的频率
            hash[key]++;
 
        for(auto iter : hash){   //维护容量为k的最小堆
            que.push(iter);
            if(que.size() > k)
                que.pop();
        }
        
        while(k > 0){    
            ans[k-1] = que.top().first;  //倒序输出
            que.pop();
            k--;
        }
        return ans;
    }
};

【关注公众号DoCode,每日一道LeetCode,将零碎时间利用起来】

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 堆是一棵满足一定性质的二叉树,具体的讲堆具有如下性质:父节点的键值总是不大于它的孩子节点的键值(小顶堆), 堆可以...
    9527Roy阅读 684评论 0 0
  • 347_(前K个高频元素)Top K Frequent Element 1 问题描述、输入输出与样例 1.1 问题...
    程序员乔戈里阅读 1,076评论 0 1
  • 一、题目简介及问题分析 原题链接:中文版、英文版 本文首发于心安-XinAnzzZ 的个人博客,转载请注明出处~ ...
    XinAnzzZ阅读 239评论 0 0
  • 排序算法几种分类方式: 1,稳定排序和不稳定排序 如果a==b, 当排序之前a在b的前面,排序后,a仍然在b...
    fly_ever阅读 456评论 0 0
  • 动态规划 111. 爬楼梯思路类似斐波那契数列注意考虑第 0 阶的特殊情况 272. 爬楼梯 II思路类似上题,只...
    6默默Welsh阅读 2,487评论 0 1