Top K Frequent Elements
Input: nums = [1,1,1,2,2,3], k = 2
Output: [1,2]
Input: nums = [1], k = 1
Output: [1]Solutions
π§ Cpp
Last updated
Input: nums = [1,1,1,2,2,3], k = 2
Output: [1,2]
Input: nums = [1], k = 1
Output: [1]Last updated
#include <map>
class Solution
{
public:
vector<int> topKFrequent(vector<int>& nums, int k)
{
std::map<int, int> input_map;
for(int i : nums)
input_map[i]++;
//sort by values(freqency)
std::multimap<int, int> sorted_input_map;
for(auto p : input_map)
sorted_input_map.insert({p.second, p.first});
vector<int> res;
for(auto iter = --sorted_input_map.end(); k--; --iter)
res.push_back(iter->second);
return res;
}
};