面试题9:用两个栈实现队列

Posted ivyharding

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了面试题9:用两个栈实现队列相关的知识,希望对你有一定的参考价值。

这一题还是挺难的,有两个栈stackA、stackB,A是入栈的,B是出栈的,入栈时,直接进入A即可,出栈时,先判断是否有元素,

如果B没有元素,pop肯定报错,应该先将A中所有的元素压倒B里面,再pop最上面一个元素,如果B中有就直接pop出,就可以,

这是最优的思路,两个栈实现了先进后出,在一起又实现了队列的先进先出。

技术图片

 

以上是关于面试题9:用两个栈实现队列的主要内容,如果未能解决你的问题,请参考以下文章

剑指offer-面试题9-用两个栈实现队列-栈和队列

面试题9-用两个栈来实现一个队列,完成队列的Push和Pop操作

校招面试 之 剑指offer第9-1题 用两个栈实现一个队列

校招面试 之 剑指offer第9-2题 用两个队列实现一个栈

[剑指offer]面试题7:用两个栈实现队列

LeetCode | 面试题09. 用两个栈实现队列剑指OfferPython