请你实现一个队列。
操作:
push x:将 x x 加入队尾,保证 x x 为 int 型整数。
pop:输出队首,并让队首出队
front:输出队首:队首不出队
输入描述:
第一行为一个正整数 n n ,代表操作次数。(1≤n≤100000)(1≤n≤100000)
接下来的 n n ,每行为一个字符串,代表一个操作。保证操作是题目描述中三种中的一种。
输出描述:
如果操作为push,则不输出任何东西。
如果为另外两种,若队列为空,则输出 "error“
否则按对应操作输出。
示例1
输入:
6
push 1
pop
front
push 2
push 3
pop
输出:
1
error
2
将输入的字符串存储至ArrayList中,然后用subString截取指令
public static void main(String[] args) {
LinkedList list = new LinkedList();
ArrayList<String> arrayList = new ArrayList<>();
Scanner scanner = new Scanner(System.in);
int count = scanner.nextInt();
for (int i = 0; i <= count; i++) {
String operate = scanner.nextLine();
arrayList.add(i,operate);
}
for (int i = 0; i < arrayList.size(); i++) {
if (arrayList.get(i).contains("push")){
String substring = arrayList.get(i).substring(5);
int num = Integer.parseInt(substring);
list.addLast(num);
}else if (arrayList.get(i).contains("pop")){
if (list.isEmpty()){
System.out.println("error");
}else {
System.out.println(list.pop());
}
}else if (arrayList.get(i).contains("front")){
if (list.isEmpty()){
System.out.println("error");
}else {
System.out.println(list.getFirst());
}
}
}
}