C++基于堆实现了查找数组中最大的 k 个元素

使用小顶堆实现元素从小到达排列

#include <iostream>
#include <vector>
#include <queue>

using namespace std;

priority_queue<int, vector<int>, greater<int>> topKHeap(vector<int> &nums, int k) {
    // 初始化小顶堆
    priority_queue<int, vector<int>, greater<int>> heap;
    // 将数组的前 k 个元素入堆
    for (int i = 0; i < k; i++) {
        heap.push(nums[i]);
    }
    // 从第 k+1 个元素开始,保持堆的长度为 k
    for (int i = k; i < nums.size(); i++) {
        // 若当前元素大于堆顶元素,则将堆顶元素出堆、当前元素入堆
        if (nums[i] > heap.top()) {
            heap.pop();
            heap.push(nums[i]);
        }
    }
    return heap;
}

int main() {
    vector<int> nums = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5};
    int k = 4;
    priority_queue<int, vector<int>, greater<int>> result = topKHeap(nums, k);

    // 输出堆中的元素
    while (!result.empty()) {
        cout << result.top() << " ";
        result.pop();
    }
    cout << endl;

    return 0;
}
 

最近更新

  1. TCP协议是安全的吗?

    2024-04-08 20:20:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-08 20:20:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-08 20:20:01       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-08 20:20:01       20 阅读

热门阅读

  1. sentaurus学习笔记(三)

    2024-04-08 20:20:01       14 阅读
  2. 递归实现字符串长度的计算

    2024-04-08 20:20:01       15 阅读
  3. Istio-learning-note-about-Fault Injection(二)

    2024-04-08 20:20:01       13 阅读
  4. Web爬虫

    Web爬虫

    2024-04-08 20:20:01      14 阅读
  5. js与jq之间的联系(补)

    2024-04-08 20:20:01       16 阅读
  6. RPA投资:成本效益分析秘籍

    2024-04-08 20:20:01       14 阅读
  7. 基于 Spring Task实现单体项目架构的定时任务

    2024-04-08 20:20:01       16 阅读