博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
优先队列小结
阅读量:4969 次
发布时间:2019-06-12

本文共 968 字,大约阅读时间需要 3 分钟。

优先队列priority_queue

头文件#include<queue>;

基本优先队列的形式priority_queue<int>que;

作用:对队列里的元素默认从大到小排列。

复杂一点的优先队列:priority_queue<type, container, functional>que;

type 为数据类型, container 为保存数据的容器,functional 为元素比较方式。

container 必须是用数组实现的容器,比如 vector, deque 但不能用 list.

       STL里面默认用的是 vector. 比较方式默认用 operator< , 所以如果你把后面俩个参数缺省的话,优先队列就是大顶堆,队头元素最大。

重点:优先队列里比较函数的写法:

priority_queue
, less
> q;//等价于默认,从大到小排//greater
从小到大排

2.自定义优先级:

struct cmp{    bool operator ()(const node &a, const node &b)    {        return a.value>b.value;// 按照value从小到大排列    }};priority_queue
, cmp>que;
3.对结构体进行重载操作符:
struct node {     int x,y;     friend bool operator < (node a, node b)     {         return a.x>b.x;    //x小的优先级高。     }  };

也可以:

struct node{  int x,y;  };  bool operator(const node &a,const node &b)  {  return a.x>b.x;  };      priority_queue
que;
bool operator < (const point a) const //升序排列     {          return x

转载于:https://www.cnblogs.com/acer1238/p/9165476.html

你可能感兴趣的文章
PL/SQL Developer 查询的数据有乱码或者where 字段名=字段值 查不出来数据
查看>>
宏定义
查看>>
笔记:git基本操作
查看>>
生成php所需要的APNS Service pem证书的步骤
查看>>
JavaWeb之JSON
查看>>
HOT SUMMER 每天都是不一样,积极的去感受生活 C#关闭IE相应的窗口 .
查看>>
windows平台上编译mongdb-cxx-driver
查看>>
optionMenu-普通菜单使用
查看>>
2016-2017-2点集拓扑作业[本科生上课时]讲解视频
查看>>
GNU/Linux超级本ZaReason Ultralap 440体验
查看>>
将github上托管的代码 在我的域名下运行
查看>>
【Manthan, Codefest 18 (rated, Div. 1 + Div. 2) C】Equalize
查看>>
【codeforces 767A】Snacktower
查看>>
【MemSQL Start[c]UP 3.0 - Round 1 C】 Pie Rules
查看>>
Ognl中“%”、“#”、“$”详解
查看>>
我对应用软件——美团的看法
查看>>
执行了的程序,才是你的程序.
查看>>
struts2.x + Tiles2.x读取多个xml 配置文件
查看>>
表单校验之datatype
查看>>
python第六篇文件处理类型
查看>>