优先队列

普通优先队列:

头文件:#include<queue>、#include<functional>

定义:

   (默认:从大到小)priority_queue<int> que;

   (自定义:从大到小)priority_queue<int,vector<int>,less<int> > que;

   (最后两个'>'间要有个空格,下同)

   (自定义:从小到大)prioity_queue<int,vector<int>,greater<int> > que;

操作:

   增加新元素——que.push(a[i]);

   删除队首元素——que.pop();

   访问队首元素——que.top();

   查询元素个数:que.size();

   判断队列空否:que.empty();(空为真)

 结构体优先队列:

头文件:#include<queue>

定义:

step 1:定义所需结构体 

   struct node

   {

    int data;

    char c;

   }; 

step 2:定义排序方式

按data的大小 从大到小排:

   bool operator<(node a,node b)

   {

     return a.data<b.data;

   }

sept 3:定义结构体优先队列

priority_queue<node> que;

操作:

   增加新元素:que.push({5,'c'});

   删除队首元素:que.pop();

   访问队首元素:que.top().data\que.top().c;

   查询元素个数:que.size();

   判断队列空否:que.empty();(空为真)

 

posted @ 2020-02-03 18:01  John-C  阅读(132)  评论(0编辑  收藏  举报