首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >缩小std::priority_queue

缩小std::priority_queue
EN

Stack Overflow用户
提问于 2012-08-27 21:33:36
回答 3查看 182关注 0票数 1

给定添加元素的速度比通过重复弹出最佳元素的通常过程移除元素的速度更快的std::priority_queue,使得程序将耗尽存储器,除非执行了某些操作,

有没有办法丢弃最差的一半元素,而让最好的一半像往常一样一次处理一个呢?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-08-27 21:44:40

没有直接的方法。但是二进制堆无论如何都不能真正支持这个操作。

但要间接做到这一点并不难:

  • Create a temporary empty priority queue
  • 交换主队列和临时队列
  • 进入一个循环,该循环从临时队列弹出并推送到主
  • Stop,当您对复制的临时队列数量感到满意时。
票数 3
EN

Stack Overflow用户

发布于 2012-08-27 21:44:00

显然不是,因为std::priority_queue的接口非常有限。您可以实现自己的优先级队列,这将允许您使用make_heap、push_heap和pop_heap (这就是std::priority_queue的实现方式)并实现自己的函数来删除最差的一半元素。

票数 3
EN

Stack Overflow用户

发布于 2012-08-27 21:46:17

std::priority_queue是一个2-heap,因此只有部分排序。与提取元素不同,数据结构对于定位元素的最佳一半没有用处。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12143042

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档