随笔 - 112  文章 - 0  评论 - 0  阅读 - 1426

前k个高频元素(优先队列)

给你一个整数数组 nums 和一个整数 k ,请你返回其中出现频率前 k 高的元素。你可以按 任意顺序 返回答案。

 

示例 1:

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

示例 2:

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



复制代码
class Solution {
public:
    vector<int> topKFrequent(vector<int>& nums, int k) {
        int n = nums.size();
        map<int,int> mp;
        //建立元素与出现次数的映射关系
        for(int i=0;i<n;i++){
            mp[nums[i]]++;
        }
        //priority_queue提供了一个最大堆(默认情况下)的功能,即降序排序
        priority_queue<pair<int,int>> q;
        for(auto it = mp.begin();it!=mp.end();it++){
            q.push({it->second,it->first});
        }
        vector<int> res;
        while(k--){
            res.push_back(q.top().second);
            q.pop();
        }
        return res;
    }
};
复制代码

 

posted on   _月生  阅读(3)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具
· Manus的开源复刻OpenManus初探
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示