(剑指offer) 用两个栈来实现一个队列

用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。

思路:由于栈是后进先出,所以先依次进入栈1,再从栈1依次弹出到栈2,这样栈1和栈2元素的顺序就正好相反了,然后弹出栈2顶部的元素,就完成了一个先进先出的过程。

维护两个栈 stack1 和 stack2,其中 stack1 用于存储元素,stack2 用于辅助操作。当栈2不为空时,在栈2顶部的元素是最先进入队列的元素,可以弹出,当栈2为空时把栈1中的元素逐个压入栈2中。

var Stack1 = []
var Stack2 = []
function push(node)
{
    // write code here
    Stack1.push(node)
    

}
function pop()
{
    // write code here
    //判断为空的情况
    if (Stack1.length ==0 && Stack2.length == 0) {
        return false
    }
    if (Stack2.length == 0) {
        while(Stack1.length !==0) {
            Stack2.push(Stack1.pop())
        }
    }
    return Stack2.pop()
}

拓展——用两个队列实现一个栈的pop和push操作

var queue1 = []
var queue2 = []
function push (node) {
    //推入的时候要判断哪个队列中有值,就推入那个队列中
    if(queue1.length !== 0) {
        queue1.push(node)
    }else {
        queue2.push(node)
    }
}
//假设栈现在有三个元素a,b,c,我们现在要删除c
function pop () {
    //弹出的时候判断哪个队列中有值,则先将该队列中的n-1个值弹出并存入另一个队列中,然后弹出最后一个值则为结果
    if(queue1.length === 0) {
        while(queue2.length !== 1) {
            queue1.push(queue2.pop()) //依次从queue2中删除元素a,b并且加入到queue1中
        }
        return queue2.pop() //最后再删除
    }else {
        while(queue1.length !== 1) {
            queue2.push(queue1.pop())
        }
        return queue1.pop()
    }
}

 

posted @ 2020-03-17 22:53  leahtao  阅读(113)  评论(0编辑  收藏  举报