C++ 中的 Priority Queues

官方参考文档:priority_queue - C++ Reference - cplusplus.com

本文译自 https://www.fluentcpp.com/2018/03/20/heaps-and-priority-queues-in-c-part-3-queues-and-priority-queues/

无意间搜到这篇文章,十分喜欢作者对 Priority Queues 的介绍,特此翻译过来分享给大家。

priority queue 是一个不遵循先入先出规则的队列。

在 priority queue 中,我们可以添加连续的数据 ,并在常数时间内得到具有最高优先级的数据。

因此,要实现一个 priority queue,我们需要指定元素之间的比较规则来确定哪个元素具有较高的优先级。

在 C++ 中,我们可以使用 std::priority_queue 来包装另一个容器(默认是 std::vector)。std::priority_queue 默认使用 std::less 来比较元素。因此具有最高优先级的元素是 最大的 那个元素。

std::priority_queue 也允许我们自定义比较方式。比如,我们可以使用 std::greater,这样的话,具有最高优先级的元素是 最小的。我们也可以用其他的自定义比较符来比较自定义类型等。

std::priority_queue 提供了优先队列的接口:

  • push:在队列中添加新的元素
  • pop:移除队列中优先级最高的元素
  • top:访问队列中优先级最高的元素

什么时候优先队列有用?一个例子是处理具有不同优先级的传入事件。我们希望根据事件的优先级处理事件,而不是根据事件的到达顺序。

堆实际上是优先队列的一种实现方式。

关于优先队列的运用,可以参考一下 Leetcode 数组中的第K个最大元素

该题可以使用自定义比较方式来用优先队列来模拟一个最小堆来完成。

int findKthLargest(vector<int>& nums, int k) {
    priority_queue<int, vector<int>, greater<int>> q;

    for (int num : nums) {
        q.push(num);

        if (q.size() > k) {
            q.pop();
        }
    }

    return q.top();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值