【问题描述】
使用两个栈实现队列,完成队列的Push和Pop操作

【解题思路】

  • in 栈用来处理入栈(push)操作,out 栈用来处理出栈(pop)操作。
  • 一个元素进入 in 栈之后,出栈的顺序被反转。
  • 当元素要出栈时,需要先进入 out 栈,此时元素出栈顺序再一次被反转,因此出栈顺序就和最开始入栈顺序是相同的,先进入的元素先退出,这就是队列的顺序。

【代码实现】

Stack<Integer> in = new Stack<>();
    Stack<Integer> out = new Stack<>();

    public void push(int node) {
        in.push(node);
    }

    public int pop() throws Exception {
        if (out.isEmpty()) {
            while (!in.isEmpty()) {
                out.push(in.pop());
            }
        }
        if (out.isEmpty()) {
            throw new RuntimeException("queue is empty");
        }
        return out.pop();
    }