LeetCode #225 用队列实现栈

本贴最后更新于 1560 天前,其中的信息可能已经物是人非

225.png

Problem Description

  • 使用队列实现栈的下列操作:
    • push(x) -- 元素 x 入栈
    • pop() -- 移除栈顶元素
    • top() -- 获取栈顶元素
    • empty() -- 返回栈是否为空

node

  • 你只能使用队列的基本操作-- 也就是 push to back, peek/pop from front, size, 和 is empty 这些操作是合法的。
  • 你所使用的语言也许不支持队列。 你可以使用 list 或者 deque(双端队列)来模拟一个队列 , 只要是标准的队列操作即可。
  • 你可以假设所有操作都是有效的(例如, 对一个空的栈不会调用 pop 或者 top 操作)。

Solution

双向队列 Deque 实现

利用双端队列 Deque 接口的实现类 LinkedList 可以很简洁的完成,Deque 拥有一个 boolean offerFirst(E e); 方法。因为底层是双向链表,prev 和 next 指针可以很好帮你实现头尾乱 ♂ 插。

class MyStack {

    Deque<Integer> deque;
  
    public MyStack() {
        deque = new LinkedList<>();
    }
  
    public void push(int x) {
        deque.offerFirst(x);
    }
  
    public int pop() {
        return deque.remove() ;
    }
  
    public int top() {
        return deque.element();
    }
  
    public boolean empty() {
        return deque.isEmpty();
    }

}

双队列形成一个闭环

  1. 2 个单向队列 queue 和 reverseQueue;
  2. queue 初次 push 时,判断是否为空,为空直接调用 offer 方法;
  3. 当 queue 不为空时,将所有的元素从头部出队,入队到 reverseQueue。queue 入队新的元素;
  4. 这时两个队列,queue 只有新的元素在队列中,reverseQueue 拥有 queue 刚刚出队的元素;
  5. 再次将 reverseQueue 的元素循环出队到 queue,保证每次调用 push 方法时,该队列是空的;
  6. 两个单项队列变成闭环。

225Queue.png

class MyStack {

    Queue<Integer> queue;
    Queue<Integer> reverseQueue;
  
    public MyStack() {
        queue = new LinkedList<>();
        reverseQueue = new LinkedList<>();
    }
  
    public void push(int x) {
        /**
         * 利用两个单向队列
         */
        if (queue.isEmpty()) {
            queue.offer(x);
        } else {
            reverseQueue.addAll(queue);
            queue.clear();
            queue.offer(x);
            queue.addAll(reverseQueue);
            reverseQueue.clear();
        }
    }

    public int pop() {
        return queue.remove();
    }

    public int top() {
        return queue.element();
    }

    public boolean empty() {
        return queue.isEmpty();
    }
}

单个单向队列

其中注意:不要使用自身的 forEach 方法,根据队列的长度搞个循环即可。

push 方法核心代码:

/*
 * 单个单向队列
 */
public void push(int x) {
    singleQueue.add(x);
    for (int i = 0; i < singleQueue.size() - 1; i++) {
        singleQueue.add(singleQueue.poll());
    }
}

注意是 size - 1。因为最新 add 的那个元素不需要执行 poll 方法。

  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖
  • 队列
    6 引用 • 1 回帖
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3187 引用 • 8213 回帖
  • 算法
    428 引用 • 254 回帖 • 24 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...