题目链接:
难度:中等
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;
}
};