STL专项:deque 双端队列

deque

dequequeue 的升级版,全称为 double-ended queue ,队头和队尾都支持入队和出队,同时还支持遍历,所有操作时间复杂度均为O(1)

声明

deque<int> dq;

常用操作

dq.push_front(x);//在队头插入元素

dq.push_back(x);//在队尾插入元素

dq.front();//获取队头元素

dq.back();//获取队尾元素

//获取队列大小

dq.size();

//判断队列是否为空

dq.empty();

//以下两个操作注意判断队列非空

dq.pop_front();//弹出队头

dq.pop_back();//弹出队尾

遍历deque

//用迭代器遍历

for(auto it = dq.begin(); it != dq.end(); it ++){

cout << *it << ' ';

}

//用基于范围的for循环

for(const auto &val : dq) cout << val << ' ';

一起写论文

一起写论文 | 星码StarryCoding 算法竞赛新手村

代码

删除前一定要记得判空!!!

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

void solve(){
	int N;cin>>N;
	deque<string> dq;
	for(int i=1;i<=N;i++){
		char a,b;cin>>a>>b;
		if(b=='w'){
			string s;cin>>s;
			if(a=='f'){
				dq.push_front(s);
			}else{
				dq.push_back(s);
			}
		}else if(b=='d'){
			if(!dq.size()) continue;
			if(a=='f') dq.pop_front();
			else dq.pop_back();
		}
	}
	if(dq.empty()) cout<<'#';
	else{
		while(dq.size()){
			cout<<dq.front();
			dq.pop_front();
		}
	}
}

int main(){
	int _;cin>>_;
	while(_--) solve();
	return 0;
}
相关推荐
玄同7652 小时前
从 0 到 1:用 Python 开发 MCP 工具,让 AI 智能体拥有 “超能力”
开发语言·人工智能·python·agent·ai编程·mcp·trae
czy87874752 小时前
深入了解 C++ 中的 `std::bind` 函数
开发语言·c++
消失的旧时光-19432 小时前
从 Kotlin 到 Dart:为什么 sealed 是处理「多种返回结果」的最佳方式?
android·开发语言·flutter·架构·kotlin·sealed
yq1982043011562 小时前
静思书屋:基于Java Web技术栈构建高性能图书信息平台实践
java·开发语言·前端
一个public的class2 小时前
你在浏览器输入一个网址,到底发生了什么?
java·开发语言·javascript
Jinkxs2 小时前
Gradle - 与Groovy/Kotlin DSL对比 构建脚本语言选择指南
android·开发语言·kotlin
&有梦想的咸鱼&2 小时前
Kotlin委托机制的底层实现深度解析(74)
android·开发语言·kotlin
我在人间贩卖青春2 小时前
C++之继承的方式
c++·private·public·protected·继承方式
BD_Marathon3 小时前
设计模式——依赖倒转原则
java·开发语言·设计模式
devmoon3 小时前
在 Polkadot Runtime 中添加多个 Pallet 实例实战指南
java·开发语言·数据库·web3·区块链·波卡