LeetCode实战:最小栈
背景
- 为什么你要加入一个技术团队?
- 如何加入 LSGO 软件技术团队?
- 我是如何组织“算法刻意练习活动”的?
- 为什么要求团队的学生们写技术Blog
题目英文
Design a stack that supports push, pop, top, and retrieving the minimum element in constant time.
- push(x) – Push element x onto stack.
- pop() – Removes the element on top of the stack.
- top() – Get the top element.
- getMin() – Retrieve the minimum element in the stack.
Example:
MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin(); --> Returns -3.
minStack.pop();
minStack.top(); --> Returns 0.
minStack.getMin(); --> Returns -2.
题目中文
设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的栈。
- push(x) – 将元素 x 推入栈中。
- pop() – 删除栈顶的元素。
- top() – 获取栈顶元素。
- getMin() – 检索栈中的最小元素。
示例:
MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin(); --> 返回 -3.
minStack.pop();
minStack.top(); --> 返回 0.
minStack.getMin(); --> 返回 -2.
算法实现
利用单链表的方式
public class MinStack
{/** initialize your data structure here. */private readonly IList<int> _lst;public MinStack(){_lst = new List<int>();}public void Push(int x){_lst.Add(x);}public void Pop(){_lst.RemoveAt(_lst.Count - 1);}public int Top(){return _lst[_lst.Count - 1];}public int GetMin(){return _lst.Min();}
}/*** Your MinStack object will be instantiated and called as such:* MinStack obj = new MinStack();* obj.Push(x);* obj.Pop();* int param_3 = obj.Top();* int param_4 = obj.GetMin();*/
利用辅助栈的方式
public class MinStack
{/** initialize your data structure here. */private readonly Stack<int> _stack;private readonly Stack<int> _stackMin;public MinStack(){_stack = new Stack<int>();_stackMin = new Stack<int>();}public void Push(int x){_stack.Push(x);if (_stackMin.Count == 0 || _stackMin.Peek() >= x){_stackMin.Push(x);}}public void Pop(){int x = _stack.Pop();if (_stackMin.Peek() == x){_stackMin.Pop();}}public int Top(){return _stack.Peek();}public int GetMin(){return _stackMin.Peek();}
}/*** Your MinStack object will be instantiated and called as such:* MinStack obj = new MinStack();* obj.Push(x);* obj.Pop();* int param_3 = obj.Top();* int param_4 = obj.GetMin();*/
实验结果
利用单链表的方式
- 状态:通过
- 18 / 18 个通过测试用例
- 执行用时: 776 ms, 在所有 C# 提交中击败了 22.32% 的用户
- 内存消耗: 33.8 MB, 在所有 C# 提交中击败了10.60% 的用户
利用辅助栈的方式
- 状态:通过
- 18 / 18 个通过测试用例
- 执行用时: 192 ms, 在所有 C# 提交中击败了 96.43% 的用户
- 内存消耗: 33.5 MB, 在所有 C# 提交中击败了 13.63% 的用户
相关图文
1. “数组”类算法
- LeetCode实战:三数之和
- LeetCode实战:最接近的三数之和
- LeetCode实战:求众数
- LeetCode实战:缺失的第一个正数
- LeetCode实战:快乐数
- LeetCode实战:寻找两个有序数组的中位数
- LeetCode实战:盛最多水的容器
- LeetCode实战:删除排序数组中的重复项
- LeetCode实战:搜索旋转排序数组
- LeetCode实战:螺旋矩阵
- LeetCode实战:螺旋矩阵 II
2. “链表”类算法
- LeetCode实战:两数相加
- LeetCode实战:删除链表的倒数第N个节点
- LeetCode实战:两两交换链表中的节点
- LeetCode实战:旋转链表
- LeetCode实战:环形链表
3. “栈”类算法
- LeetCode实战:有效的括号
- LeetCode实战:最长有效括号
- LeetCode实战:逆波兰表达式求值
4. “队列”类算法
- LeetCode实战:设计循环双端队列
- LeetCode实战:滑动窗口最大值
- LeetCode实战:整数反转
- LeetCode实战:字符串转换整数 (atoi)
5. “递归”类算法
- LeetCode实战:爬楼梯
6. “字符串”类算法
- LeetCode实战:反转字符串
- LeetCode实战:翻转字符串里的单词
- LeetCode实战:最长公共前缀
- LeetCode实战:字符串相加
- LeetCode实战:字符串相乘
7. “树”类算法
- LeetCode实战:相同的树
- LeetCode实战:对称二叉树
- LeetCode实战:二叉树的最大深度
- LeetCode实战:将有序数组转换为二叉搜索树
8. “哈希”类算法
- LeetCode实战:两数之和
9. “排序”类算法
- LeetCode实战:合并两个有序数组
- LeetCode实战:合并两个有序链表
- LeetCode实战:合并K个排序链表
10. “搜索”类算法
- LeetCode实战:搜索二维矩阵
- LeetCode实战:子集
11. “动态规划”类算法
- LeetCode实战:最长回文子串
- LeetCode实战:最大子序和
- LeetCode实战:不同路径
12. “回溯”类算法
- LeetCode实战:全排列
13. “数值分析”类算法
- LeetCode实战:回文数
- LeetCode实战:x 的平方根
LeetCode实战:最小栈相关推荐
- leetcode 155. 最小栈
难度:简单 频次:59 题目: 设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈. 实现 MinStack 类: MinStack() 初始化堆栈对象. void ...
- LeetCode:155. 最小栈
题目链接 155.最小栈 题目描述 设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的栈. push(x) -- 将元素 x 推入栈中. pop() -- 删除栈顶的元素. ...
- leetcode 155. 最小栈(常数时间获取最小值,需要维护两个栈)
题目 思路 左神讲过的经典算法,维护两个栈: stack,用来存储数据 minStack,用来存储每个位置情况下的最小值,类似于动态规划. 每次入栈2个元素,一个是入栈的元素本身,一个是当前栈元素的最 ...
- leetcode题目-最小栈和用两个栈实现队列
1.用两个栈实现队列 a栈用来存放加入的数 b栈用来存放要删除的数 当b栈存在数据时,就把top的元素pop掉 直到b栈中没有数据存放,再重新遍历a栈,把a的数据倒着遍历进b栈.也就是b栈存放着倒着的 ...
- LeetCode 155.最小栈
设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈. 实现 MinStack 类: MinStack() 初始化堆栈对象. void push(int val) 将元 ...
- leetcode - 155. 最小栈
设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的栈. push(x) – 将元素 x 推入栈中. pop() – 删除栈顶的元素. top() – 获取栈顶元素. get ...
- Leetcode 155. 最小栈 (每日一题 20210923)
设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈.push(x) -- 将元素 x 推入栈中. pop() -- 删除栈顶的元素. top() -- 获取栈顶元素. ...
- LeetCode 716. 最大栈(双栈 / list+map)
文章目录 1. 题目 2. 解题 2.1 双栈解法 2.2 list+map 1. 题目 设计一个最大栈,支持 push.pop.top.peekMax 和 popMax 操作. push(x) -- ...
- Leetcode刷题 155题: 最小栈(基于python3和c++两种语言)
** Leetcode刷题 155题: 最小栈(基于python3和c++两种语言) ** ** 题目: ** 设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈. ...
最新文章
- 计算机数字信号原理,计算机网络通信原理数字信号的基带传输.ppt
- Biztalk发布web服务时遭遇'SoapExceptionInternal SOAP Processing Failure'错误
- queue源码java_看看AbstractQueue源码Java9
- JUnit 5 –动态测试
- Qt笔记-解决键盘事件不能正常响应(其他响应事件通用)
- 基于Python3-Pygame的推箱子游戏
- UE4之SetRelativeLocation 和SetRelativeRotation
- SQL中FOR XML子句的各种用法,包括FOR XML字句的四种基本模式:AUTO模式、RAW模式、PATH模式和EXPLICIT模式...
- LOJ6031 「雅礼集训 2017 Day1」字符串 SAM、根号分治
- 【路径规划】基于matlab A_star算法机器人静态避障路径规划【含Matlab源码 495期】
- (Windows)Scala学习3--列表、数组
- 苹果wifi测试中文软件,WiFi测评大师
- 【C51】单片机芯片之——图解74HC595
- 途游游戏 DevOps 实践|都说「单元测试」好,「AAAC四步法」少不了
- 用起这 16 个顶尖 Vue 开源项目,节约更多的时间摸鱼
- Alex网络结构解析
- 计算机蓝屏安全模式都启动不了,stop:0x00000074蓝屏无法进入安全模式无法开机 解决办法...
- matlab实现图像DCT变换
- VC6.0执行 link.exe 时出错
- 决策树与K-近邻分类随堂笔记(二)
热门文章
- 2014计算机三级网络技术,2014计算机三级网络技术综合题解题思路
- mysql5.7.22密码设置_mysql5.7.22版本修改root密码
- 小说站 章节内容 ajax,第17章 作业分析与异步编程原理——2019年5月14日22:00
- 网站ui的配色有哪些需要注意的?
- leetcode--括号生成--python
- 关于Android H5混合开发遇到的问题
- python学习------tab补全
- centos查看特定程序占用端口情况
- 双边滤波算法的简易实现bilateralFilter
- Android APP测试的日志文件抓取