LeetCode 232 用栈实现队列

Leetcode 232 用栈实现队列

题目描述:
使用栈实现队列的下列操作:

  • push(x) -- 将一个元素放入队列的尾部。
  • pop() -- 从队列首部移除元素。
  • peek() -- 返回队列首部的元素。
  • empty() -- 返回队列是否为空。

辅助栈/双栈

  • 输入栈(负责接收输入add())
  • 输出栈(负责调整顺序并输出peek()、pop())

执行用时:0 ms, 在所有 Java 提交中击败了100.00%的用户
内存消耗:37.6 MB, 在所有 Java 提交中击败了18.03%的用户

class MyQueue {
    private List<Integer> listIn;
    private List<Integer> listOut;

    /** Initialize your data structure here. */
    public MyQueue() {
        //初始化
        this.listIn = new ArrayList<>();
        this.listOut = new ArrayList<>();
    }
    
    /** Push element x to the back of queue. */
    public void push(int x) {
        listIn.add(x);
    }
    
    /** Removes the element from in front of queue and returns that element. */
    public int pop() {
        int peekElem = peek();
        listOut.remove(listOut.size()-1);
        return peekElem;
    }
    
    /** Get the front element. */
    public int peek() {
        /*转移元素到listOut*/
        if(listOut.isEmpty()) {
            for(int idx=listIn.size()-1; idx>=0; idx--) {
                listOut.add(listIn.get(idx));
            }
            listIn.clear();
        }

        int peekElem = listOut.get(listOut.size()-1);
        return peekElem;
    }
    
    /** Returns whether the queue is empty. */
    public boolean empty() {
        return listIn.isEmpty() && listOut.isEmpty();
    }
}
posted @ 2020-08-26 18:39  CodeSPA  阅读(87)  评论(0编辑  收藏  举报