leetcode 347. 前 K 个高频元素
2024-10-16 10:24:13
问题描述
给定一个非空的整数数组,返回其中出现频率前 k 高的元素。
示例 1:
输入: nums = [1,1,1,2,2,3], k = 2
输出: [1,2]
示例 2:
输入: nums = [1], k = 1
输出: [1]
提示:
你可以假设给定的 k 总是合理的,且 1 ≤ k ≤ 数组中不相同的元素的个数。
你的算法的时间复杂度必须优于 O(n log n) , n 是数组的大小。
题目数据保证答案唯一,换句话说,数组中前 k 个高频元素的集合是唯一的。
你可以按任意顺序返回答案。
代码
class Solution {
public:
vector<int> topKFrequent(vector<int>& nums, int k) {
map<int,int> table;
int i,n= nums.size();
priority_queue<pair<int,int>> q;
vector<int> ans(k);
for(auto &a:nums)
++table[a];
for(auto &t:table)
q.push({t.second,t.first});
for(i = 0; i < k; ++i)
{
ans[i] = q.top().second;
q.pop();
}
return ans;
}
};
priority_queue默认先按照pair的first元素降序,first元素相等时,再按照second元素降序.我们要对元素的数目进行排序,因此t.second放在前面,后面ans我们要得到具体的数而不是这个数值的个数,因此是q.top().second,对应t.first.priority_queue与map的使用可以看一个小例子.
结果
执行用时:44 ms, 在所有 C++ 提交中击败了47.97%的用户
内存消耗:14.1 MB, 在所有 C++ 提交中击败了6.25%的用户
最新文章
- 最全面的 C++ 资源、框架大全
- poj 2594Treasure Exploration(有向图路径可相交的最小路径覆盖)
- 那些年我们学过的PHP黑魔法
- 剑指Offer43 n个骰子点数概率
- 使用link在两个容器之间建立连接(mysql)
- Linux使用问答
- Unity-资源
- Hyperion Essbase BusinessRule 函数学习--2
- flash导入图片缩放后出现毛边、失真、锯齿、文字模糊不清晰的情况
- 【Java集合类】ArrayList详解 (JDK7)
- Java设计模式之(建造者模式)
- Angular2+AngularJS
- redis中的hash、列表、集合操作
- Flask 自定义过滤器多个参数传入
- java内部类和异常类的概念
- tp3.2上传图片生成缩略图
- 理解TIME_WAIT
- 插件写法之脚本运行环境,mac和window检测
- js 引入外部文件之 script 标签
- HGOI 20181028 题解
热门文章
- Table.Group分组…Group(Power Query 之 M 语言)
- 突出显示(Project)
- 小迪安全 Web安全 基础入门 - 第十天 - 信息打点-APP&;小程序篇&;抓包封包&;XP框架&;反编译&;资产提取
- 【LeetCode】311. Sparse Matrix Multiplication 解题报告 (C++)
- 【LeetCode】890. Find and Replace Pattern 解题报告(Python & C++)
- LeetCode—剑指 Offer学习计划
- C++异常处理(try catch throw)完全攻略
- Java初学者作业——定义客户类(Customer),客户类的属性包括:姓名、年龄、电话、余额、账号和密码;方法包括:付款。
- jquery控制元素的隐藏和显示的几种方法
- 编写Java程序,现要求使用 dom4j 解析 city.xml 文档,实现省份及对应城市的联动特效,效果如图所示