問題描述
在未排序的數組中找到第 k 個最大的元素。請注意,你需要找的是數組排序後的第 k 個最大的元素,而不是第 k 個不同的元素。
示例 1:
輸入: [3,2,1,5,6,4] 和 k = 2
輸出: 5
解題報告
priority_queue<int,vector<int>, greater<int>>pq;
元素從小到大順序出隊的優先隊列priority_queue<int> q;
元素從大到小順序出隊的優先隊列。
實現代碼
class Solution {
public:
int findKthLargest(vector<int>& nums, int k) {
priority_queue<int,vector<int>, greater<int>>pq;
for(int i=0;i<k;i++)pq.push(nums[i]);
for(int i=k;i<nums.size();i++){
if(pq.top()<nums[i]){
pq.pop();
pq.push(nums[i]);
}
}
return pq.top();
}
};