leetcode 347. 前 K 个高频元素

问题描述

给定一个非空的整数数组,返回其中出现频率前 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%的用户
posted @ 2020-07-09 10:58  曲径通霄  阅读(98)  评论(0编辑  收藏  举报