力扣215. 数组中的第K个最大元素

2023-12-14 04:52:36

堆排序

  • 前言
  • 思路:
    • 使用一个 size = k 小顶堆,之后的元素如果大于堆顶,则将堆顶 pop 后,将此元素入堆,遍历完成后,堆顶即为 TopK 元素;
    • 使用了 stl 的优先队列数据结构,默认是大顶堆,小顶堆的构造为:
      • std::priority_queue<int, std::vector<int>, std::greater<int>>

class Solution {
public:
    int findKthLargest(vector<int>& nums, int k) {
        std::priority_queue<int, std::vector<int>, std::greater<int>> pq;

        int size = nums.size();
        for (int i = 0; i < size; ++i) {
            if (i < k) {
                pq.push(nums[i]);
            } else {
                if (nums[i] > pq.top()) {
                    pq.pop();
                    pq.push(nums[i]);
                }
            }
        }

        return pq.top();
    }
};

文章来源:https://blog.csdn.net/N_BenBird/article/details/134819232
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。