leetcode347.前K个高频元素

先使用map,统计每个字符出现的频率,然后使用优先队列根据字符出现频率存储字符,然后弹出堆中元素,弹出K次完成操作!

如果看不懂本题CPP语法的,可以参考我的另外一篇博客------------->CPP优先队列priority_queue,定义比较器,重载operator()

cpp 复制代码
class less1{
    public:
    bool operator()(const pair<int,int>& p1,const pair<int,int>& p2){
        return p1.second<p2.second;
    }
};

class Solution {
public:
    vector<int> topKFrequent(vector<int>& nums, int k) {
        unordered_map<int,int> m;
        vector<int> ans;
        for(int i=0;i<nums.size();++i){
            m[nums[i]]++;
        }
        priority_queue<pair<int,int>,vector<pair<int,int>>,less1> pq;
        for(const auto& item:m){
            pq.push(item);
        }
        for(int i=0;i<k;++i){
            ans.push_back(pq.top().first);
            pq.pop();
        }
        return ans;
    }
};
相关推荐
Lostgreen17 天前
堆(Heap)的原理与C++实现
数据结构·堆排序·
轩情吖20 天前
二叉树-堆(补充)
c语言·数据结构·c++·后端·二叉树··排序
apocelipes1 个月前
Linux glibc自带哈希表的用例及性能测试
c语言·c++·哈希表·linux编程
keysky1 个月前
「SPOJ2666」QTREE4 - Query on a tree IV
线段树··树链剖分
_DCG_1 个月前
数据结构之哈希表详解
数据结构·哈希表
一直学习永不止步1 个月前
LeetCode题练习与总结:随机翻转矩阵--519
java·数学·算法·leetcode·哈希表·水塘抽样·随机化
DogDaoDao1 个月前
leetcode 面试经典 150 题:字母异位词分组
算法·leetcode·面试·vector·哈希表·数据结构与算法·字母异位词分组
DogDaoDao1 个月前
leetcode 面试经典 150 题:有效的字母异位词
c++·leetcode·面试·字符串·哈希算法·哈希表·字母异位词
Tisfy2 个月前
LeetCode 1705.吃苹果的最大数目:贪心(优先队列) - 清晰题解
算法·leetcode·优先队列·贪心·
硕风和炜2 个月前
【LeetCode: 1338. 数组大小减半 + 哈希表 + 贪心】
算法·leetcode·散列表·贪心·哈希表