priority_queue<Type, Container, Functional> // greater<>表示小根堆css
vector<int> topKFrequent(vector<int>& nums, int k) { priority_queue<pair<int,int>,vector<pair<int,int>>,greater<pair<int,int>>> minHeap; unordered_map<int,int> count; for(int i : nums){ ++count[i]; } for(auto& x:count){ auto pair = make_pair(x.second, x.first); if(minHeap.size()==k){ if(pair < minHeap.top()) continue; minHeap.pop(); } minHeap.push(move(pair)); } vector<int> ans(k,0); while(!minHeap.empty()){ ans[--k]=minHeap.top().second; minHeap.pop(); } return ans; }