当前位置: 首页 > news >正文

LeetCode347:前K个高频元素

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

在这里插入图片描述
解题思想
使用优先队列
priority_queue<Type, Container, Functional>
Type 就是数据类型,Container 就是容器类型(Container必须是用数组实现的容器,比如vector,deque等等,但不能用 list。STL里面默认用的是vector),Functional 就是比较的方式,当需要用自定义的数据类型时才需要传入这三个参数,使用基本数据类型时,只需要传入数据类型,默认是大顶堆

//升序队列
priority_queue <int,vector<int>,greater<int> > q;
//降序队列
priority_queue <int,vector<int>,less<int> >q;//greater和less是std实现的两个仿函数
//(就是使一个类的使用看上去像一个函数。其实现就是类中实现一个operator(),这个类就有了类似函数的行为,就是一个仿函数类了

代码

class Solution {
public:class cmp{public:bool operator()(const pair<int,int>& l, const pair<int,int>& r){return l.second > r.second;}};vector<int> topKFrequent(vector<int>& nums, int k) {unordered_map<int,int> umap;for(int i = 0; i < nums.size(); ++i){++umap[nums[i]];}priority_queue<pair<int, int>, vector<pair<int, int>>, cmp> pri_que;for(auto it = umap.begin(); it != umap.end(); ++it){pri_que.push(*it);if(pri_que.size() > k) pri_que.pop();}vector<int> res(k);for(int i = 0; i < k; i++){res[i] = pri_que.top().first;pri_que.pop();}return res;}
};
http://www.lryc.cn/news/378778.html

相关文章:

  • 2.线上论坛项目
  • Java面试题:讨论synchronized关键字和java.util.concurrent包中的同步工具,如Lock和Semaphore
  • 酱香型白酒派系介绍
  • 编译chamfer3D报错
  • BuildConfig类找不到,BuildConfig.java类不在编译加载路径问题解决
  • 海外版coze前端代码助手
  • python pyautogui实现图片识别点击失败后重试
  • 怎么看电脑实时充电功率
  • Qt 实战(4)信号与槽 | 4.2、自定义信号与槽
  • Android开发系列(六)Jetpack Compose之Box
  • 51单片机STC89C52RC——4.1 独立按键(数码管显示按键值)
  • 解决双击bootstrap.bat没有生成b2.exe文件
  • AI穿戴设备是未来手机的终结者?中国AI商业化的未来预测
  • FPGA+Nvidia Orin NX+AI 异构视频图像处理开发平台在高端医疗和工业检测的应用,支持定制,支持国产化
  • 2000-2023年各省名义GDP、实际GDP、GDP平减指数数据(含原始数据+计算过程+计算结果)(以2000年为基期)
  • python学习—字典(Dictionary)
  • 鸿蒙开发:【组件启动规则(FA模型)】
  • 网络编程5----初识http
  • “用友审批+民生付款”,YonSuite让企业发薪更准时
  • EtherCAT扫盲,都是知识点
  • 开发中遇到的错误 - @SpringBootTest 注解爆红
  • 数据仓库的实际应用示例-广告投放平台为例
  • Beyond VL了解学习
  • AI音乐革命:创意产业的新篇章
  • python从入门到精通1:注释
  • CountDownLatch(应对并发问题的工具类)
  • HarmonyOS开发知识 :扩展修饰器,实现节流、防抖、权限申请
  • 自然语言NLP的基础处理
  • 带颜色的3D点云数据发布到ros1中(通过rviz显示)python、C++
  • python学习—列表和元组