力扣:用栈实现队列

题目

在这里插入图片描述

解题

class MyQueue {
    Deque<Integer> inStack;
    Deque<Integer> outStack;

    public MyQueue() {
        inStack = new ArrayDeque<Integer>();
        outStack = new ArrayDeque<Integer>();
    }

    public void push(int x) {
        inStack.push(x);
    }

    public int pop() {
        if(outStack.isEmpty()){
            while(!inStack.isEmpty()){
                outStack.push(inStack.pop());
            }
        }
        return outStack.pop();
    }

    public int peek() {
        if(outStack.isEmpty()){
            while(!inStack.isEmpty()){
                outStack.push(inStack.pop());
            }
        }
        return outStack.peek();
    }

    public boolean empty() {
        if(inStack.isEmpty() && outStack.isEmpty()){
            return true;
        }
        return false;
    }
}

思路

首先我们了解队列规律是“先进先出”,而栈的规律是“先进后出”,所以用一个栈的话模拟不出来队列的功能。
而想要模拟出来队列的话就需要改变栈的出的顺序,这样我们就可以用两个栈,一个为出栈,一个为入栈。当有元素要进入的时候就加入到入栈中,然后当有元素要出的时候,就把入栈的元素加入到出栈中,这样就可以把入栈最下面的元素变为出栈最上面的元素,这样顺序就没有错了。

画图说明:
在这里插入图片描述

所以上面的各个方法中就poppeak方法需要注意的是,入栈的元素加入到出栈元素的时机。只有当我们出栈元素为空的时候才能将当前入栈中所有元素加入到出栈中,而不是每次出栈都是将入栈的加入到出栈的,这样会影响到整体的顺序,就比如先加入1、2、3中三个元素,然后要出队列了,就转移到出栈中,然后把1弹出,这时加入4,然后要出队列,这时把4加入到出栈就会弹出4导致顺序错误。
我们可以理解为每一次出栈为空把入栈转移过来之后,就把当前的一个状态给记录下来了,保证了当前所有元素的有序性,而需要把这段有序的给全部出完之后,再传入下一段有序的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值