码迷,mamicode.com
首页 > 其他好文 > 详细

容器适配器————priority_queue

时间:2019-09-01 16:35:07      阅读:75      评论:0      收藏:0      [点我收藏+]

标签:副本   empty   inf   cti   第一个   type   play   移除   return   

#include <queue>

priority_queue 容器适配器定义了一个元素有序排列的队列。默认队列头部的元素优先级最高。因为它是一个队列,所以只能访问第一个元素,这也意味着优先级最高的元素总是第一个被处理。但是如何定义“优先级”完全取决于我们自己。

技术图片

 

priority_queue<Type, Container, Functional>

  • Type 就是数据类型,
  • Container 就是容器类型(Container必须是用数组实现的容器,比如vector,deque等等,但不能用 list。STL里面默认用的是vector),
  • Functional 就是比较的方式,当需要用自定义的数据类型时才需要传入这三个参数,使用基本数据类型时,只需要传入数据类型
priority_queue<int,vector<int>,greater<int> > q;//升序排序,小顶堆

priority_queue <int,vector<int>,less<int> >q;//降序排序,默认降序,大顶堆

 其中比较函数可以这么写:

bool cmp(int &a,int &b){
    return a>b;
}
priority_queue<int,vector<int>, cmp>;//降序排序

 

操作

  • push(const T& obj):将obj的副本放到容器的适当位置,这通常会包含一个排序操作。
  • push(T&& obj):将obj放到容器的适当位置,这通常会包含一个排序操作。
  • emplace(T constructor a rgs...):通过调用传入参数的构造函数,在序列的适当位置构造一个T对象。为了维持优先顺序,通常需要一个排序操作。
  • top():返回优先级队列中第一个元素的引用。
  • pop():移除第一个元素。
  • size():返回队列中元素的个数。
  • empty():如果队列为空的话,返回true。
  • swap(priority_queue<T>& other):和参数的元素进行交换,所包含对象的类型必须相同。

 

容器适配器————priority_queue

标签:副本   empty   inf   cti   第一个   type   play   移除   return   

原文地址:https://www.cnblogs.com/pacino12134/p/11442330.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!