C++ 优先队列

#include <queue>

priority_queue<Type, Container, Functional>:Type为数据的类型,Container为数据存储的容器类型,Functional为比较函数

默认是vector,最大堆

下面,描述如何定制优先队列

我们在这里关注比较函数的实现,对于比较函数有两种方式,一种是定义单独的比较函数,另一种是在定义的数据类型内部定义比较策略

一、仿函数体现出比一般的函数更大的灵活性,我们使用仿函数来实现

struct cmpmin{
bool operator ()(int& a,int &b){
return a>b;
}
}; struct cmpmax{
bool operator() (int& a,int& b){
return a<b;
}
};

当定义大于号的时候是小数优先,当定义小于号的时候是大数优先

实际上仿函数可以看做是对小于号的重载。

二、在数据类型内部加以定义

struct minnode{
int data;
bool operator < (const minnode& node) const{
return this->data>node.data;
}
}; struct maxnode{
int data;
bool operator < (const maxnode& node)const{
return this->data<node.data;
}
};

这里实现小于号(实际上只能实现小于号,实现大于号会报错),它的意义和上面是一样的,

当定义大于号的时候是小数优先,当定义小于号的时候是大数优先。

总是外部定义和内部实现一致的时候是递增,如果不一致时递减

下面举个栗子

int nums[]={,,,,,,,,,};
minnode minnodes[]={,,,,,,,,,};
maxnode maxnodes[]={,,,,,,,,,};
int main()
{
queue<int> q;//normal queue
priority_queue<int,vector<int>,cmpmin> minq;//minimum queue
priority_queue<int,vector<int>,cmpmax> maxq;//maximum queue
priority_queue<minnode,vector<minnode> >minnodeq;
priority_queue<maxnode,vector<maxnode> >maxnodeq;
for(int i=;i<;i++){
q.push(nums[i]);
minq.push(nums[i]);
maxq.push(nums[i]);
minnodeq.push(minnodes[i]);
maxnodeq.push(maxnodes[i]);
}
cout<<""<<q.front()<<" "<<q.back()<<endl;// 3 15

   cout << "top of minq " << minq.top() << endl;//1
     cout << "top of maxq " << maxq.top() << endl;//43
    cout << "top of minnodeq " << minnodeq.top().data << endl;//1
   cout << "top of maxnodeq " <<maxnodeq.top().data << endl;//43

    return ;
}

在一些操作上,queue和priority_queue是不一样的,前者是一个线性的结构,因此可以使用队前,队尾函数,也就是front(),back(),但是优先队列的意义已经和传统的队列的意义不太一样了,实际上是一个堆,队前、队尾函数不可用,可以使用的函数是top()。两者都可以使用pop()函数来去掉队首或者堆顶的数据。

C++ 优先队列的更多相关文章

  1. 堆排序与优先队列——算法导论(7)

    1. 预备知识 (1) 基本概念     如图,(二叉)堆是一个数组,它可以被看成一个近似的完全二叉树.树中的每一个结点对应数组中的一个元素.除了最底层外,该树是完全充满的,而且从左向右填充.堆的数组 ...

  2. 数据结构:优先队列 基于list实现(python版)

    #!/usr/bin/env python # -*- coding:utf-8 -*- #Author: Minion-Xu #list实现优先队列 class ListPriQueueValueE ...

  3. python优先队列,队列和栈

    打印列表的疑问 class Node: def __str__(self): return "haha" print([Node(),Node()]) print(Node()) ...

  4. 数据结构作业——Sanji(优先队列)

    山治的婚约 Description 我们知道,山治原来是地下有名的杀人家族文斯莫克家族的三子,目前山治的弟弟已经出现,叫做四治,大哥二哥就叫汪(One)治跟突(Two)治好了(跟本剧情无关) .山治知 ...

  5. Java优先队列

    按照Java api的说法: java.util.PriorityQueue.PriorityQueue() Creates a PriorityQueue with the default init ...

  6. 优先队列实现Huffman编码

    首先把所有的字符加入到优先队列,然后每次弹出两个结点,用这两个结点作为左右孩子,构造一个子树,子树的跟结点的权值为左右孩子的权值的和,然后将子树插入到优先队列,重复这个步骤,直到优先队列中只有一个结点 ...

  7. “玲珑杯”ACM比赛 Round #7 B -- Capture(并查集+优先队列)

    题意:初始时有个首都1,有n个操作 +V表示有一个新的城市连接到了V号城市 -V表示V号城市断开了连接,同时V的子城市也会断开连接 每次输出在每次操作后到首都1距离最远的城市编号,多个距离相同输出编号 ...

  8. Dijkstra算法优先队列实现与Bellman_Ford队列实现的理解

    /* Dijkstra算法用优先队列来实现,实现了每一条边最多遍历一次. 要知道,我们从队列头部找到的都是到 已经"建好树"的最短距离以及该节点编号, 并由该节点去更新 树根 到其 ...

  9. 数据结构作业——ギリギリ eye(贪心+优先队列/贪心+并查集)

    ギリギリ eye Description A.D.1999,由坠落地球的“谜之战舰”带来的 Over Technology,揭示了人类历史和远古文明之间的丝丝联系, 促使人类终止彼此间的战争,一方面面 ...

  10. javascript数据结构-优先队列

    这里之所以扩充一个 有限队列 是因为,生活使用中队列通常会附加优先级,比如排队买票,一般老人和军人等会有优先权限. 实现:继承上篇的 普通队列实现.这里用一种方法,入队的时候,进行排序插入到指定位置, ...

随机推荐

  1. sql 简单事务例子

    BEGIN TRY BEGIN TRAN ) BEGIN UPDATE table SET ... END ELSE BEGIN UPDATE table SET ... UPDATE table S ...

  2. Entity Framwork(EF) 7——在现在数据库的甚而上开发MVC 新项目

    一.开发背景: 由于老系统已经无法满足实际业务需求,需在现有数据库的甚而上开发新的项目. 二.困难点: 而EF默认情况下是要删除现有数据库表格后重新创建,这是不允许的.当你创建数据库对象时系统会提示“ ...

  3. Maven实战(四)生命周期

    1. 三套生命周期     Maven拥有三套相互独立的生命周期,它们分别为clean,default和site. 每个生命周期包含一些阶段,这些阶段是有顺序的,并且后面的阶段依赖于前面的阶段,用户和 ...

  4. Gradient Boosting Decision Tree学习

    Gradient Boosting Decision Tree,即梯度提升树,简称GBDT,也叫GBRT(Gradient Boosting Regression Tree),也称为Multiple ...

  5. hive中的桶

    hive中有桶的概念,对于每一个表或者分区,可以进一步组织成桶,说白点,就是更细粒度的数据范围.hive采用列值哈希,然后除以桶的个数以求余的方式决定该条记录存放在哪个桶当中.使用桶的好处:1.获得更 ...

  6. Jquery实现简单到计时功能(setTimeout,setInterval)

    要实现一个标签或者按钮进行5秒到计时,非常简单,直接上代码: 倒计时:<span id="timeSpan1" style="color:red;font-size ...

  7. oracle rownum paging issues

    rownum是oracle预处理字段,默认标序是1,只有记录集已经满足条件后才会进行后续编号.由于第一条记录rownum默认是1,而你的条件是rownum>=6 对第一条记录比较它的rownum ...

  8. sed命令手册

    sed 是一种在线编辑器,它一次处理一行内容. 处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space). 接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内 ...

  9. C语言基础_2

    scanf函数可以从键盘上读取数据并记录到变量中.为了使用这个函数也需要在文件开头使用如下的预处理指令#include <stdio.h>scanf函数使用的时候所需要的初始数据和prin ...

  10. PL/SQL中SELECT总结

      一.SELECT 语句的各个关键词的顺序及作用简解(这个我简略点写~) 1.SELECT 2.FROM 3.WHERE 4.GROUP BY ---对结果集进行分组,通常与聚合函数一起使用 5.H ...