模拟队列
题目描述
实现一个队列,队列初始为空,支持四种操作:
(1) “push x” – 向队尾插入一个数x;
(2) “pop” – 从队头弹出一个数;
(3) “empty” – 判断队列是否为空;
(4) “query” – 查询队头元素。
现在要对队列进行M个操作,其中的每个操作3和操作4都要输出相应的结果。
输入格式
第一行包含整数M,表示操作次数。
接下来M行,每行包含一个操作命令,操作命令为”push x”,”pop”,”empty”,”query”中的一种。
输出格式
对于每个”empty”和”query”操作都要输出一个查询结果,每个结果占一行。
其中,”empty”操作的查询结果为“YES”或“NO”,”query”操作的查询结果为一个整数,表示队头元素的值。
数据范围1≤M≤100000,
1≤x≤109,所有操作保证合法。
输入样例:10
push 6
empty
query
pop
empty
push 3
push 4
pop
query
push 6输出样例:NO
6
YES
4
Solution
import java.util.*;
import java.io.*;class Main{static final int N = 100010;static int[] queue = new int[N];static int hh = 0, tt = 0;public static void main(String[] args) throws IOException{BufferedReader br = new BufferedReader(new InputStreamReader(System.in));BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));String[] s = br.readLine().split(" ");int m = Integer.parseInt(s[0]);while(m > 0){m--;s = br.readLine().split(" ");if(s[0].equals("push")){int x = Integer.parseInt(s[1]);queue[tt] = x;tt++;}else if(s[0].equals("pop")){hh++;}else if(s[0].equals("empty")){if(hh >= tt) bw.write("YES\n");else bw.write("NO\n");}else if(s[0].equals("query")){bw.write(queue[hh] + "\n");}}bw.close();br.close();}
}