https://leetcode.cn/problems/implement-queue-using-stacks/
题面
使用栈实现队列的下列操作:
push(x) – 将一个元素放入队列的尾部。
pop() – 从队列首部移除元素。
peek() – 返回队列首部的元素。
empty() – 返回队列是否为空。
示例:
1 2 3 4 5 6
| MyQueue queue = new MyQueue(); queue.push(1); queue.push(2); queue.peek(); queue.pop(); queue.empty();
|
说明:
- 你只能使用标准的栈操作 – 也就是只有 push to top, peek/pop from top, size, 和 is empty 操作是合法的。
- 你所使用的语言也许不支持栈。你可以使用 list 或者 deque(双端队列)来模拟一个栈,只要是标准的栈操作即可。
- 假设所有操作都是有效的 (例如,一个空的队列不会调用 pop 或者 peek 操作)。
代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
| class MyQueue { public: stack<int> stackIn, stackOut; MyQueue() {}
void push(int val) { stackIn.push(val); }
int pop() { if (stackOut.empty()) { while (!stackIn.empty()) { stackOut.push(stackIn.top()); stackIn.pop(); } } int result = stackOut.top(); stackOut.pop(); return result; }
int peek() { int result = this->pop(); stackOut.push(result); return result; }
bool empty() { return stackIn.empty() && stackOut.empty(); } }
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
| Stack<Integer> stackIn; Stack<Integer> stackOut;
public MyQueue() { stackIn = new Stack<>(); stackOut = new Stack<>(); }
public void push(int val) { stackIn.push(val); }
public int pop() { dumpstackIn(); return stackOut.pop(); }
public int peek() { dumpstackIn(); return stackOut.peek(); }
public boolean empty() { return stackIn.isEmpty() && stackOut.isEmpty(); }
private void dumpstackIn() { if (!stackOut.isEmpty()) return; while (!stackIn.isEmpty()) stackOut.push(stackIn.pop()); }
|