题目描述[原题链接][https://www.acwing.com/problem/content/description/36/]
请用栈实现一个队列,支持如下四种操作:
- push(x) – 将元素x插到队尾;
- pop() – 将队首的元素弹出,并返回该元素;
- peek() – 返回队首元素;
- empty() – 返回队列是否为空;
注意:
- 你只能使用栈的标准操作:
push to top
,peek/pop from top
,size
和is empty
; - 如果你选择的编程语言没有栈的标准库,你可以使用list或者deque等模拟栈的操作;
- 输入数据保证合法,例如,在队列为空时,不会进行
pop
或者peek
等操作;
样例
1 | MyQueue queue = new MyQueue(); |
算法描述
初始化两个栈,压入操作直接压入第一个栈即可,弹出和取队列首部元素需要将数据转入另一个栈中,操作完后再将数据装回,判空即判断第一个栈是否为空即可,单向队列就可以实现了;
C++代码
1 | class MyQueue { |
Java代码
1 | class MyQueue { |