背景

  • 为什么你要加入一个技术团队?
  • 如何加入 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实战:最小栈相关推荐

  1. leetcode 155. 最小栈

    难度:简单 频次:59 题目: 设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈. 实现 MinStack 类: MinStack() 初始化堆栈对象. void ...

  2. LeetCode:155. 最小栈

    题目链接 155.最小栈 题目描述 设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的栈. push(x) -- 将元素 x 推入栈中. pop() -- 删除栈顶的元素. ...

  3. leetcode 155. 最小栈(常数时间获取最小值,需要维护两个栈)

    题目 思路 左神讲过的经典算法,维护两个栈: stack,用来存储数据 minStack,用来存储每个位置情况下的最小值,类似于动态规划. 每次入栈2个元素,一个是入栈的元素本身,一个是当前栈元素的最 ...

  4. leetcode题目-最小栈和用两个栈实现队列

    1.用两个栈实现队列 a栈用来存放加入的数 b栈用来存放要删除的数 当b栈存在数据时,就把top的元素pop掉 直到b栈中没有数据存放,再重新遍历a栈,把a的数据倒着遍历进b栈.也就是b栈存放着倒着的 ...

  5. LeetCode 155.最小栈

    设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈. 实现 MinStack 类: MinStack() 初始化堆栈对象. void push(int val) 将元 ...

  6. leetcode - 155. 最小栈

    设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的栈. push(x) – 将元素 x 推入栈中. pop() – 删除栈顶的元素. top() – 获取栈顶元素. get ...

  7. Leetcode 155. 最小栈 (每日一题 20210923)

    设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈.push(x) -- 将元素 x 推入栈中. pop() -- 删除栈顶的元素. top() -- 获取栈顶元素. ...

  8. LeetCode 716. 最大栈(双栈 / list+map)

    文章目录 1. 题目 2. 解题 2.1 双栈解法 2.2 list+map 1. 题目 设计一个最大栈,支持 push.pop.top.peekMax 和 popMax 操作. push(x) -- ...

  9. Leetcode刷题 155题: 最小栈(基于python3和c++两种语言)

    ** Leetcode刷题 155题: 最小栈(基于python3和c++两种语言) ** ** 题目: ** 设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈. ...

最新文章

  1. @override注解可以不写吗
  2. 常用的下载文献的地方
  3. 读入自然数m、n,判断m/n是有限小数还是循环小数
  4. 在职场中,什么是职场大忌?
  5. linux c++开发环境_玩转 WSL 在 Win10 上打造 Linux 开发环境
  6. 社交网络分析算法应用,社交网络分析算法
  7. iShot--免费Mac截图工具
  8. android 简历 android 3年 上海.doc
  9. 年轻时代,噢,年轻时代
  10. 解决word2016复制粘贴后一直未响应
  11. 磁盘空间清理·微信文件夹
  12. 路由器接口及静态路由配置
  13. Linux命令分隔符
  14. 磁盘存储链式的B树与B+树
  15. 【epoll函数】epoll_create、epoll_ctl、epoll_wait
  16. pb 调用虹软_Python进阶量化交易专栏场外篇12-股票分笔数据跨周期处理
  17. 2D变形:平移、旋转、缩放、倾斜
  18. 谷歌浏览器的页面保存为图片
  19. 天下大势,分久必合,合久必分
  20. Spring - RabbitMQ循环依赖问题解决

热门文章

  1. android 模板方法模式,安卓设计模式(七)模板方法模式
  2. PHP流程控制语句例题,第四堂、php流程控制语句
  3. 后端开发面试自我介绍_字节跳动暑期实习后端开发面试经历
  4. 一线互联网常见的14个Java面试题,你颤抖了吗程序员
  5. 完美数据迁移-MongoDB Stream的应用
  6. Windows 7 开发新特性
  7. Tomcat 7.x热部署
  8. Android 系统启动过程
  9. 如何处理单元测试产生的数据,下列哪些说法是正确的
  10. php更新用户数据为空,php – Instagram实时更新标签 – 获取空数据,为什么?