题目描述
请用栈实现一个队列,支持如下四种操作:
- push(x) - 将原始x插入队尾;
- pop() - 将队首的元素弹出,并返回该元素;
- peek() - 返回队首元素;
- empty() - 返回队列是否为空;
注意:
- 你只能使用栈的标准操作:
push
、pop
、empty
和top
; - 如果你选择的编程语言没有栈的标准库,你可以使用list或者queue等模拟栈的操作;
- 输入数据保证合法,例如,在队列为空时,不会进行
pop
或者peek
等操作;
样例
MyQueue queue = new MyQueue();
queue.push(1);
queue.push(2);
queue.peek(); // return 1
queue.pop(); // return 1
queue.empty(); // return false
解题思路
-
描述
本题目为模拟题。
栈的特性为“先进后出”,队列的特性为“先进先出”。
使用两个栈,“先进后出” + “后进先出” = “先进先出”。 -
实现代码: