(1)为了运用priority_queue,你必须包含头文件<queue>:#include<queue>

(2)在头文件中priority_queue定义如下:
namespace std{
template <class T, class Container = vector<T>,
class Compare = less<typename Container::value_type> >
class priority_queue;
}
第一个template参数代表元素型别,带有默认值的第二个参数用来定义priority_queue内部存放元素所用的实际容器,缺省采用vector。第三个参数定义出“用以搜索下一个最高优先元素”的排序准则,缺省下是以operator <作为比较标准。实际上priority_queue只是很单纯的把各项操作转化为内部容器的对应调用,你可以使用任何序列式容器来支持priority_queue,只要它们支持随机存取迭代器和front(),push_back(),pop_back()等动作就行了。由于priority_queue需要用到STL heap算法,所以其内部容器必须支持随机存取迭代器。 (3)priority_queue的各项操作:
priority_queue::priority_queue()
默认构造函数,产生一个空priority_queue explicit priority_queue::priority_queue(const ComFunc& op)
产生一个priority_queue,以op为排序准则 priority_queue::priority_queue(const ComFunc& op, const Container& cont)
产生一个priority_queue,以op为排序准则,并以容器cont内的元素为初值(复制) priority_queue::priority_queue(InputIterator beg, InputIterator end)
产生一个priority_queue,以区间[beg, end)内的元素为初值 priority_queue::priority_queue(InputIterator beg, InputIterator end, const ComFunc& op)
产生一个priority_queue,以区间[beg, end)内的元素为初值,以op为排序准则 priority_queue::priority_queue(InputIterator beg, InputIterator end, const ComFunc& op, const Container& cont)
产生一个priority_queue,以区间[beg, end)内的元素为初值,以op为排序准则及容器cont内的元素为初值 size_type priority_queue::size() const
返回元素个数 bool priority_queue::empty() const
判断priority_queue是否为空 void priority_queue::push(const value_type& elem)
将elem的副本插入priority_queue const value_type& priority_queue::top() const
返回priority_queue的“下一个”元素,调用者必须确保priority_queue不为空否则可能是未定义的行为 void priority_queue::pop()
移除priority_queue的“下一个”元素,调用者必须确保priority_queue不为空否则可能是未定义的行为

  

STL中priority_queue小结的更多相关文章

  1. STL 中priority_queue小结

    (1)为了运用priority_queue,你必须包含头文件<queue>:#include<queue>    (2)在头文件中priority_queue定义如下: nam ...

  2. STL中stack小结

    (1)为了运用stack,你必须包含头文件<stack>:#include<stack> (2)在头文件中stack定义如下: namespace std{ template ...

  3. STL中vector小结

    ()使用vector之前必须包含头文件<vector>:#include<vector> ()namespace std{ template <class T, clas ...

  4. 浅谈C++ STL中的优先队列(priority_queue)

    从我以前的博文能看出来,我是一个队列爱好者,很多并不是一定需要用队列实现的算法我也会采用队列实现,主要是由于队列和人的直觉思维的一致性导致的. 今天讲一讲优先队列(priority_queue),实际 ...

  5. STL中的优先级队列priority_queue

    priority_queue(queue类似)完全以底部容器为根据,再加上二叉堆(大根堆或者小根堆)的实现原理,所以其实现非常简单,缺省情况下priority_queue以vector作为底部容器.另 ...

  6. STL中sort、priority_queue、map、set的自定义比较函数

    STL中,sort的默认排序为less,也就是说从小到大排序:priority_queue默认是less,也就说大顶堆:map默认是less,也就说用迭代器迭代的时候默认是小的排在前面:set默认是l ...

  7. STL中的set容器的一点总结

    1.关于set C++ STL 之所以得到广泛的赞誉,也被很多人使用,不只是提供了像vector, string, list等方便的容器,更重要的是STL封装了许多复杂的数据结构算法和大量常用数据结构 ...

  8. 【转】 STL中的set容器的一点总结

    1.关于set C++ STL 之所以得到广泛的赞誉,也被很多人使用,不只是提供了像vector, string, list等方便的容器,更重要的是STL封装了许多复杂的数据结构算法和大量常用数据结构 ...

  9. (转)STL中set的用法

    转载自here 1.关于set map容器是键-值对的集合,好比以人名为键的地址和电话号码.相反地,set容器只是单纯的键的集合.例如,某公司可能定义了一个名为bad_checks的set容器,用于记 ...

随机推荐

  1. maven pom.xml报错

    再在项目上强制update一下就可以了 如下: 此外使用maven时用默认的仓库速度会过慢 下载很小的jar包都需要很久 推介使用oschina的源 使用在这里:

  2. android: 使用 AsyncTask

    9.2.4    使用 AsyncTask 不过为了更加方便我们在子线程中对 UI 进行操作,Android 还提供了另外一些好用的工 具,AsyncTask 就是其中之一.借助 AsyncTask, ...

  3. raspberry pi 如何汉化显示中文

    1 树莓派初装系统之后,首次启动会出现“raspi-config”工具,如下图:(若不是初次启动,在命令模式下,请输入 sudo raspi-config 命令,即可调出此界面.若在图形桌面下,打开桌 ...

  4. [3].jekyll的基础

    一.创建新项目 以下是一个获取最简单 Jekyll 模板并生成静态页面的方法.: Administrator@FANGPENG /e $ jekyll new myblog # 创建名为 myblog ...

  5. Android 多线程-----AsyncTask详解

    您可以通过点击 右下角 的按钮 来对文章内容作出评价, 也可以通过左下方的 关注按钮 来关注我的博客的最新动态. 如果文章内容对您有帮助, 不要忘记点击右下角的 推荐按钮 来支持一下哦 如果您对文章内 ...

  6. 如何制作CSR文件?

    如何制作CSR文件? 在申请数字证书之前,您必须先生成证书私钥和证书请求文件(CSR,Cerificate Signing Request),CSR是您的公钥证书原始文件,包含了您的服务器信息和您的单 ...

  7. webpack处理Img标签路径的几种情况

    在使用webpack过程中遇到这个问题,各种搜索遇到此问题的还真不少,但都没有一个完整的说明. 后来研究下,图片除了路径替换还是就是图片做优化主是小于一定大小的通过转 base64 inline方式减 ...

  8. img标签中的图片加载异常时显示默认的图片

    备忘:

  9. NSXMLParser读取XML文件并将数据显示到TableView上

    关于XML,有两种解析方式,分别是SAX(Simple API for XML,基于事件驱动的解析方式,逐行解析数据,采用协议回调机制)和DOM(Document Object Model ,文档对象 ...

  10. 关于stacking context和CSS z-index的总结

    HTML中决定元素叠加顺序的CSS属性最有名的应该是z-index了.但是,往往在项目中发现有些情况和我们的预期不太一致.经过研究和学习,总算搞清楚了其中的关系.简单总结如下: 只有Positione ...