deque(双向队列)基本用法
deque(双向队列)基本用法
阅读体验:https://zybuluo.com/Junlier/note/1297030
简单介绍
就是可以两头插元素,两头删元素的数据结构
那么具体的STL操作(只写主要用的)
代码未经编译。。。不过我这样写肯定也过不了编译。。。
有错误、有补充、有希望楼主添加的都可以提出来吼
其实我知道就只讲操作有点不敢相信。。。
所以我下面还写了一个类型的题目,里面有用到它来实现,大概就行了吧。。。
seque<int> Q;
//定义一个双向队列 可以是任何类型的(同队列)
int main()
{
Q.empty();//检查是否为空(同队列)
Q.push_front();//从队头加元素(类比队列的Q.push())
Q.push_back(); //从队尾加元素(类比队列的Q.push())
Q.pop_front();//从队头删元素(类比队列的Q.pop())
Q.pop_back(); //从队尾删元素(类比队列的Q.pop())
Q.front();//返回队头元素(类比队列的Q.front())
Q.back(); //返回队尾元素(类比队列的Q.front())
}
大概用的多的就这些吧
0/1最短路
用到双向队列的时候一般是在跑0/1最短路时(就是边权只有0和1的最短路)
会跑的很快,这里顺便讲一下吧
不证明
类似SPFA的跑法
只不过SPFA是每次更新后放到队尾
而我们跑0/1最短路时就是当前点被边权为0的边更新就放队头,被边权为1的边更新就放队尾
说了不证明,因为我不想
放个代码,跑以S为起点的单源0/1最短路
变量名不认识的就是建边的。。。\(ljl[\) \(]\)
void Short_Road()
{
for(int i=0;i<=tot;++i)dis[i]=Inf;
while(!Q.empty())Q.pop_front();
Q.push_back(S),dis[S]=0;
while(!Q.empty())
{
int now=Q.front();Q.pop_front();
if(vis[now])continue;vis[now]=1;
for(int i=hd[now];i;i=ljl[i].nxt)
{
int qw=ljl[i].to;
if(vis[qw])continue;
if(dis[qw]>dis[now]+ljl[i].v)
{
dis[qw]=dis[now]+ljl[i].v;
if(ljl[i].v)Q.push_back(qw);
else Q.push_front(qw);
}
}
}
}
deque(双向队列)基本用法的更多相关文章
- collection系列用法-deque双向队列
deque双向队列 Deque可以从两端添加和删除元素.常用的结构,是它的简化版本. Deque支持序列的常用操作,现在举一个简单例子,你会发现其实跟平成的list没啥区别: import colle ...
- STL之deque双向队列
deque双向队列是一种双向开口的连续线性空间,可以高效的在头尾两端插入和删除元素,提供随机访问,deque在接口上和vector非常相似,下面列出deque的常用成员函数: Table 6.9. C ...
- deque双向队列(转)
deque双向队列是一种双向开口的连续线性空间,可以高效的在头尾两端插入和删除元素,deque在接口上和vector非常相似,下面列出deque的常用成员函数: deque的实现比较复杂,内部会维 ...
- 【转载】deque双向队列
继vector和queue之后,又发现一个很好用的东西. 本篇转载自http://blog.csdn.net/morewindows/article/details/6946811 deque双向队列 ...
- C++ Deque(双向队列)
C++ Deque(双向队列)是一种优化了的.对序列两端元素进行添加和删除操作的基本序列容器.它允许较为快速地随机访问,但它不像vector 把所有的对象保存在一块连续的内存块,而是采用多个连续的 ...
- STL --> deque双向队列
deque简介 deque是双向开口的连续性存储空间.虽说是连续性存储空间,但这种连续性只是表面上的,实际上它的内存是动态分配的,它在堆上分配了一块一块的动态储存区,每一块动态存储去本身是连续的,de ...
- deque双向队列
对于双向队列,与队列queue以及vector容器的区别就在于,名字不同,也就是它是双向的,可以从头开始操作,也可以从末尾开始操作. 双向队列的常用方法跟队列queue差不多: 头文件: #inclu ...
- Python_Day_05 计数器(counter),有序字典(OrderDict),默认字典(defaultdict),可命名元祖(namedtuple),双向队列(deque),单项队列(deuqe.Queue)
Counter(计数器) 是一个字典的子类,存储形式同样为字典,其中存储的键为字典的元素,值为元素出现的次数,在使用之前我们需要先导入文件 import collections 初始化一个计数器 im ...
- 计数器(counter),有序字典(OrderDict),默认字典(defaultdict),可命名元祖(namedtuple),双向队列(deque),单项队列(deuqe.Queue)
Python_Day_05 计数器(counter),有序字典(OrderDict),默认字典(defaultdict),可命名元祖(namedtuple),双向队列(deque),单项队列(deuq ...
随机推荐
- 【学习】011 JVM参数调优配置
自动内存管理机制 Java虚拟机原理 所谓虚拟机,就是一台虚拟的机器.他是一款软件,用来执行一系列虚拟计算指令,大体上虚拟机可以分为 系统虚拟机和程序虚拟机, 大名鼎鼎的Visual Box.Vmar ...
- less:匹配模式
相当于JS中的if(不完全是),满足条件后才能匹配 .margin(top, @width: 5px) { margin: @width 0 0 0; } .margin(right, @width: ...
- Flutter-charts_flutter圖表
pub.dev搜索charts_flutter 導入依賴 charts_flutter: ^0.8.1 項目導入 import 'package:charts_flutter/flutter.dart ...
- bzoj1430 小猴打架 prufer 序列
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=1430 题解 prufer 序列模板题. 一个由 \(n\) 个点构成的有标号无根树的个数为 \ ...
- django之项目部署知识点
一:项目部署的框架 nginx和uWSGI在生产服务器上进行的部署 二:什么是nginx? nginx是一个web服务器. 什么是web服务器? web服务器则主要是让客户可以通过浏览器进行访问,处理 ...
- Apache HttpClient之fluent API的使用
该方法为Apache HttpClient 4.5以上的版本支持,在官网有明确的说明. 对比以前的方式,其优点是代码更简洁,同时为线程安全的.仅举一个最简单的post栗子 JAR包信息: <de ...
- [洛谷P3486]POI2009 KON-Ticket Inspector
问题描述 Byteasar works as a ticket inspector in a Byteotian National Railways (BNR) express train that ...
- App.after
解释: App.after可以增加APP级的切面,触发的时机是在所拦截的对应生命周期方法执行之后. 方法参数:Object Object 参数说明: 参数名 类型 必填 默认值 说明 methods ...
- BZOJ 4804: 欧拉心算 欧拉函数
Description 给出一个数字N Input 第一行为一个正整数T,表示数据组数. 接下来T行为询问,每行包含一个正整数N. T<=5000,N<=10^7 题解: 求 $\sum_ ...
- 20180805-Java 异常处理
try{ //程序代码}catch(ExceptionName e1){ //Catch 块} 下面的例子中声明有两个元素的一个数组,当代码试图访问数组的第三个元素的时候就会抛出一个异常. //文件名 ...