问题描述

给定一个非空的整数数组,返回其中出现频率前 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%的用户

最新文章

  1. 最全面的 C++ 资源、框架大全
  2. poj 2594Treasure Exploration(有向图路径可相交的最小路径覆盖)
  3. 那些年我们学过的PHP黑魔法
  4. 剑指Offer43 n个骰子点数概率
  5. 使用link在两个容器之间建立连接(mysql)
  6. Linux使用问答
  7. Unity-资源
  8. Hyperion Essbase BusinessRule 函数学习--2
  9. flash导入图片缩放后出现毛边、失真、锯齿、文字模糊不清晰的情况
  10. 【Java集合类】ArrayList详解 (JDK7)
  11. Java设计模式之(建造者模式)
  12. Angular2+AngularJS
  13. redis中的hash、列表、集合操作
  14. Flask 自定义过滤器多个参数传入
  15. java内部类和异常类的概念
  16. tp3.2上传图片生成缩略图
  17. 理解TIME_WAIT
  18. 插件写法之脚本运行环境,mac和window检测
  19. js 引入外部文件之 script 标签
  20. HGOI 20181028 题解

热门文章

  1. Table.Group分组…Group(Power Query 之 M 语言)
  2. 突出显示(Project)
  3. 小迪安全 Web安全 基础入门 - 第十天 - 信息打点-APP&amp;小程序篇&amp;抓包封包&amp;XP框架&amp;反编译&amp;资产提取
  4. 【LeetCode】311. Sparse Matrix Multiplication 解题报告 (C++)
  5. 【LeetCode】890. Find and Replace Pattern 解题报告(Python & C++)
  6. LeetCode—剑指 Offer学习计划
  7. C++异常处理(try catch throw)完全攻略
  8. Java初学者作业——定义客户类(Customer),客户类的属性包括:姓名、年龄、电话、余额、账号和密码;方法包括:付款。
  9. jquery控制元素的隐藏和显示的几种方法
  10. 编写Java程序,现要求使用 dom4j 解析 city.xml 文档,实现省份及对应城市的联动特效,效果如图所示