老卫带你学---leetcode刷题(155. 最小栈)

155. 最小栈

问题:

设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。

实现 MinStack 类:

MinStack() 初始化堆栈对象。

void push(int val) 将元素val推入堆栈。

void pop() 删除堆栈顶部的元素。

int top() 获取堆栈顶部的元素。

int getMin() 获取堆栈中的最小元素。

bash 复制代码
示例 1:

输入:
["MinStack","push","push","push","getMin","pop","top","getMin"]
[[],[-2],[0],[-3],[],[],[],[]]

输出:
[null,null,null,null,-3,null,0,-2]

解释:
MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin();   --> 返回 -3.
minStack.pop();
minStack.top();      --> 返回 0.
minStack.getMin();   --> 返回 -2.
bash 复制代码
提示:

-231 <= val <= 231 - 1
pop、top 和 getMin 操作总是在 非空栈 上调用
push, pop, top, and getMin最多被调用 3 * 104 次

解决:

核心在于取得最小

那只需要在push的时候,也维护当前栈最小元素信息即可

python 复制代码
class MinStack:

    def __init__(self):
      self.stack = []

    def push(self, val: int) -> None:
      if not self.stack:
        self.stack.append([val,val])
      else:
        self.stack.append([val,min(val,self.stack[-1][1])])

    def pop(self) -> None:
      self.stack.pop()

    def top(self) -> int:
      return self.stack[-1][0]

    def getMin(self) -> int:
      return self.stack[-1][1]
相关推荐
脱氧核糖核酸__3 小时前
LeetCode热题100——234.回文链表(两种解法)
c++·算法·leetcode·链表
生信研究猿4 小时前
leetcode 416. 分割等和子集
算法·leetcode·职场和发展
6Hzlia5 小时前
【Hot 100 刷题计划】 LeetCode 24. 两两交换链表中的节点 | C++ 精准指针舞步
c++·leetcode·链表
踩坑记录8 小时前
leetcode 92. 反转链表 II 区间反转(不是整条链表反转)
leetcode·链表
6Hzlia8 小时前
【Hot 100 刷题计划】 LeetCode 148. 排序链表 | C++ 归并排序自顶向下
c++·leetcode·链表
im_AMBER8 小时前
Leetcode 162 除了自身以外数组的乘积 | 接雨水
开发语言·javascript·数据结构·算法·leetcode
啊哦呃咦唔鱼9 小时前
leetcodehot100-347. 前 K 个高频元素
数据结构·算法·leetcode
玛丽莲茼蒿9 小时前
Leetcode hot100 多数元素【简单】
算法·leetcode·职场和发展
AbandonForce9 小时前
Map类:pair键值对|map的基本操作|operator[]
开发语言·c++·算法·leetcode
田梓燊9 小时前
力扣:146.LRU 缓存
算法·leetcode·缓存