B3616 【模板】队列题解
B3616 【模板】队列
题目描述
请你实现一个队列(queue),支持如下操作:
push(x):向队列中加入一个数 xxx。pop():将队首弹出。如果此时队列为空,则不进行弹出操作,并输出ERR_CANNOT_POP。query():输出队首元素。如果此时队列为空,则输出ERR_CANNOT_QUERY。size():输出此时队列内元素个数。
输入格式
第一行,一个整数 nnn,表示操作的次数。
接下来 nnn 行,每行表示一个操作。格式如下:
1 x,表示将元素x加入队列。2,表示将队首弹出队列。3,表示查询队首。4,表示查询队列内元素个数。
输出格式
输出若干行,对于每个操作,按「题目描述」输出结果。
每条输出之间应当用空行隔开。
输入输出样例 #1
输入 #1
13
1 2
3
4
1 233
3
2
3
2
4
3
2
1 144
3
输出 #1
2
1
2
233
0
ERR_CANNOT_QUERY
ERR_CANNOT_POP
144
说明/提示
样例解释
首先插入 2,队首为 2、队列内元素个数为 1。
插入 233,此时队首为 2。
弹出队首,此时队首为 233。
弹出队首,此时队首为空。
再次尝试弹出队首,由于队列已经为空,此时无法弹出。
插入 144,此时队首为 144。
数据规模与约定
对于 100%100\%100% 的测试数据,满足 n≤10000n\leq 10000n≤10000,且被插入队列的所有元素值是 [1,1000000][1, 1000000][1,1000000] 以内的正整数。
思路
直接手写队列即可。
代码见下
#include<bits/stdc++.h>
using namespace std;
unsigned long long t,n,a[10000007],b=0,d=0,c;
string s;
int main(){
t=1;
while(t--){
b=0;
d=1;
cin>>n;
for(int i=1;i<=n;i++){
cin>>s;
if(s=="1"){
cin>>c;
a[++b]=c;
}
else if(s=="3"){
if(d<=b){
cout<<a[d]<<endl;
}
else{
cout<<"ERR_CANNOT_QUERY"<<endl;
}
}
else if(s=="4"){
cout<<b-d+1<<endl;
}
else{
if(d<=b){
d++;
}
else{
cout<<"ERR_CANNOT_POP"<<endl;
}
}
}
}
return 0;
}

浙公网安备 33010602011771号