问题描述
在未排序的数组中找到第 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();
}
};