(94)347. 前 K 个高频元素(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 个高频元素的集合是唯一的。
	你可以按任意顺序返回答案。

写了个快排 用的时间有点长了 写的有点迷
糊 生疏了。。。。
效率还行 32ms

class Solution {
    
    
public:
    void qsort(vector<pair<int, int>>& nums,int left,int right,int k) {
    
    
        if (left >= right) {
    
    
            return;
        }
        int curnum = nums[left].second;
        int curleft = left;
        int curright = right;
        while (curleft < curright) {
    
    
            while (nums[curright].second <= curnum && curleft < curright) {
    
    
                curright--;
            }
            while (nums[curleft].second >= curnum && curleft < curright) {
    
    
                curleft++;
            }
            if (curleft < curright){
    
    
                swap(nums[curleft], nums[curright]);
            }
        }
        swap(nums[curleft], nums[left]);
        if (curleft == k - 1) {
    
    
            return;
        }
        else if (curleft < k - 1) {
    
    
            qsort(nums, curleft + 1, right, k);
        }
        else {
    
    
            qsort(nums, left, curleft - 1, k);
        }
    }

    vector<int> topKFrequent(vector<int>& nums, int k) {
    
    
        unordered_map<int, int> unordmap;
        for (auto& a : nums) {
    
    
            unordmap[a]++;
        }
        vector<pair<int, int>> vec;
        auto it = unordmap.begin();
        while (it != unordmap.end()) {
    
    
            vec.emplace_back(it->first, it->second);
            it++;
        }
        qsort(vec, 0, vec.size() - 1, k);
        vector<int> ans;
        for (int i = 0; i < k; ++i) {
    
    
            ans.push_back(vec[i].first);
        }
        return ans;
    }
};

还有个方法 使用堆。。。 我看了下题解 我还以为要自己建堆呢 结果使用的priority_queue。。。

class Solution {
    
    
public:
    static bool cmp(pair<int,int> &a,pair<int,int> &b){
    
    
        return a.second>b.second;
    }
    vector<int> topKFrequent(vector<int>& nums, int k) {
    
    
        unordered_map<int, int> unordmap;
        for(auto &a:nums){
    
    
            unordmap[a]++;
        }
        auto it=unordmap.begin();
        priority_queue<pair<int,int>,vector<pair<int,int>>,decltype(&cmp)> prique(cmp);
        while(it!=unordmap.end()){
    
    
            if(prique.size()==k){
    
    
                if(prique.top().second<it->second){
    
    
                    prique.pop();
                    prique.emplace(it->first,it->second);
                }
            }else{
    
    
                prique.emplace(it->first,it->second);
            }
            it++;
        }
        vector<int> ans;
        while(!prique.empty()){
    
    
            ans.emplace_back(prique.top().first);
            prique.pop();
        }
        return ans;
    }
};

猜你喜欢

转载自blog.csdn.net/li_qw_er/article/details/108426343