C#LeetCode刷题之#225-用队列实现栈(Implement Stack using Queues)
问题
该文章的最新版本已迁移至个人博客【比特飞】,单击链接 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 的时间复杂度应当为: ,其它方法的时间复杂度应当为: 。
最新文章
- HDU4553 约会安排
- iOS中AutoLayer自动布局流程及相关方法【转】
- Scheme 编程环境的设置(racket/petite)-王垠
- 4GB内存原32位系统(x86)取舍问题,显卡共享内存Win8.1完全不用担心
- AFURLRequestSerialization
- 小K的H5之旅-HTML5与CSS3部分新属性浅见
- Ubuntu 16.04安装Docker-CE
- 100Mbps和100Mb/s有什么不同
- fortitoken
- centos 设置时间为北京时间
- 基于spec互评Alpha版本
- java List分批处理
- typedef与前向声明
- springMVC学习(注解实现依赖注入)
- ASP.NET MVC 中单独的JS文件中获取Controller中设定的值
- [转载]Angular4 组件通讯方法大全
- 我永远喜欢我的偶像 KIKU
- 优化神器 beamoff
- hibernate框架环境搭建与使用
- 716. Max Stack (follow up questions for min stack)
热门文章
- 使用Java带你打造一款简单的英语学习系统
- tcpreplay的使用指导
- 转自fineui论坛:解决fineui框架开发中的Designer.aspx.cs丢失问题
- HDU - 1520 Anniversary party (树的最大独立集)
- js获得url地址携带参数
- Html5 表单元素基础
- Django学习路22_empty为空,forloop.counter 从1计数,.counter0 从0计数 .revcounter最后末尾数字是1,.revcounter0 倒序,末尾为 0
- PHP pclose() 函数
- CF R 209 div 2 CF359B Permutation 构造
- 小波变换检测信号突变点的MATLAB实现