Lintcode40 Implement Queue by Two Stacks solution 题解

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Lintcode40 Implement Queue by Two Stacks solution 题解相关的知识,希望对你有一定的参考价值。

【题目描述】

As the title described, you should only use two stacks to implement a queue‘s actions.The queue should support push(element), pop() and top() where pop is pop the first(a.k.a front) element in the queue.Both pop and top methods should return the value of first element.

正如标题所述,你需要使用两个栈来实现队列的一些操作。队列应支持push(element),pop() 和 top(),其中pop是弹出队列中的第一个(最前面的)元素。pop和top方法都应该返回第一个元素的值。

【题目链接】

http://www.lintcode.com/en/problem/implement-queue-by-two-stacks/

【题目解析】

用两个Stack来实现一个Queue,可以考虑到push()时,几乎与Queue中的offer()一样,都是加在末尾,区别是当Stack pop()时,取出的是最近加入(newest)的元素,而Queue用poll()则是将最老(oldest)的元素取出。使用2个Stack,可以将stack2作为push()时的目标,而另一个stack1用来翻转顺序,只有当peek()或者是poll()时,才需要将元素翻转存入stack1,再进行读取。

【参考答案】

http://www.jiuzhang.com/solutions/implement-queue-by-two-stacks/


以上是关于Lintcode40 Implement Queue by Two Stacks solution 题解的主要内容,如果未能解决你的问题,请参考以下文章

lintcode586- Sqrt(x) II- medium

470. Implement Rand10() Using Rand7() (拒绝采样Reject Sampling)

CORBA 的含义 No IMPLEMENT exception

Kerio connect remove all messages from mesage queu

检查DOM元素是否完全可见

延迟一段时间后执行一个块