问题

该文章的最新版本已迁移至个人博客【比特飞】,单击链接 https://www.byteflying.com/archives/4106 访问。

使用队列实现栈的下列操作:

push(x) -- 元素 x 入栈

pop() -- 移除栈顶元素

top() -- 获取栈顶元素

empty() -- 返回栈是否为空

注意:

你只能使用队列的基本操作-- 也就是 push to back, peek/pop from front, size, 和 is empty 这些操作是合法的。

你所使用的语言也许不支持队列。 你可以使用 list 或者 deque(双端队列)来模拟一个队列 , 只要是标准的队列操作即可。

你可以假设所有操作都是有效的(例如, 对一个空的栈不会调用 pop 或者 top 操作)。


Implement the following operations of a stack using queues.

push(x) -- Push element x onto stack.

pop() -- Removes the element on top of the stack.

top() -- Get the top element.

empty() -- Return whether the stack is empty.

MyStack stack = new MyStack();

stack.push(1);

stack.push(2);

stack.top();   // returns 2

stack.pop();   // returns 2

stack.empty(); // returns false

Notes:

You must use only standard operations of a queue -- which means only push to back, peek/pop from front, size, and is empty operations are valid.

Depending on your language, queue may not be supported natively. You may simulate a queue by using a list or deque (double-ended queue), as long as you use only standard operations of a queue.

You may assume that all operations are valid (for example, no pop or top operations will be called on an empty stack).


示例

该文章的最新版本已迁移至个人博客【比特飞】,单击链接 https://www.byteflying.com/archives/4106 访问。

public class Program {

    public static void Main(string[] args) {
var stack = new MyStack(); stack.Push(1);
stack.Push(2);
stack.Push(3); Console.WriteLine(stack.Pop());
Console.WriteLine(stack.Pop());
Console.WriteLine(stack.Pop()); Console.WriteLine(stack.Empty()); Console.ReadKey();
} public class MyStack { private Queue<int> _queue = null; public MyStack() {
_queue = new Queue<int>();
} public void Push(int x) {
//基本思路是反转原队列
var queue = new Queue<int>();
queue.Enqueue(x);
foreach(var elemet in _queue) {
queue.Enqueue(elemet);
}
_queue = queue;
} public int Pop() {
return _queue.Dequeue();
} public int Top() {
return _queue.First();
} public bool Empty() {
return !_queue.Any();
} } }

以上给出1种算法实现,以下是这个案例的输出结果:

该文章的最新版本已迁移至个人博客【比特飞】,单击链接 https://www.byteflying.com/archives/4106 访问。

3
2
1
True

分析:

显而易见,Push 的时间复杂度应当为:  ,其它方法的时间复杂度应当为:  。

最新文章

  1. HDU4553 约会安排
  2. iOS中AutoLayer自动布局流程及相关方法【转】
  3. Scheme 编程环境的设置(racket/petite)-王垠
  4. 4GB内存原32位系统(x86)取舍问题,显卡共享内存Win8.1完全不用担心
  5. AFURLRequestSerialization
  6. 小K的H5之旅-HTML5与CSS3部分新属性浅见
  7. Ubuntu 16.04安装Docker-CE
  8. 100Mbps和100Mb/s有什么不同
  9. fortitoken
  10. centos 设置时间为北京时间
  11. 基于spec互评Alpha版本
  12. java List分批处理
  13. typedef与前向声明
  14. springMVC学习(注解实现依赖注入)
  15. ASP.NET MVC 中单独的JS文件中获取Controller中设定的值
  16. [转载]Angular4 组件通讯方法大全
  17. 我永远喜欢我的偶像 KIKU
  18. 优化神器 beamoff
  19. hibernate框架环境搭建与使用
  20. 716. Max Stack (follow up questions for min stack)

热门文章

  1. 使用Java带你打造一款简单的英语学习系统
  2. tcpreplay的使用指导
  3. 转自fineui论坛:解决fineui框架开发中的Designer.aspx.cs丢失问题
  4. HDU - 1520 Anniversary party (树的最大独立集)
  5. js获得url地址携带参数
  6. Html5 表单元素基础
  7. Django学习路22_empty为空,forloop.counter 从1计数,.counter0 从0计数 .revcounter最后末尾数字是1,.revcounter0 倒序,末尾为 0
  8. PHP pclose() 函数
  9. CF R 209 div 2 CF359B Permutation 构造
  10. 小波变换检测信号突变点的MATLAB实现