LeetCode热题100——155. 最小栈

https://leetcode.cn/problems/min-stack/description/?envType=study-plan-v2&envId=top-100-liked

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

实现 MinStack 类:

MinStack() 初始化堆栈对象。

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

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

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

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

示例 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.

提示:

-231 <= val <= 231 - 1

pop、top 和 getMin 操作总是在 非空栈 上调用

push, pop, top, and getMin最多被调用 3 * 104 次

题解

难点在于如何在常数时间检索到最小元素,第一反应是存一个成员变量 min,getMin时直接返回 min, 但是有个问题,如果 首先pop() 一个最小的元素,那么接下来调用 getMin该返回多少呢?

假设我们按顺序push 2,3,5,1,9 五个元素,使用 numStack 记录元素,minStack 用来记录插入元素后的最小值栈

value numStack minStack 备注
9 9 min( 1 , 9) = 1 前5个元素的最小值是1
1 1 min( 2 , 1) = 1 前4个元素的最小值是1
5 5 min( 2 , 5) = 2 前3个元素的最小值是2
3 3 min ( 2, 3) =2 前2个元素的最小值是2
2 2 min( Integer.MAX_VALUE , 2 ) = 2 前1个元素的最小值是2

例如 9被pop之后, getMin其实就是获取 前4个元素的最小值,只需要调用 minStack.peek即可

java 复制代码
private Stack<Integer> xStack;
    private Stack<Integer> minStack;

    public MinStack() {
        xStack = new Stack<Integer>();
        minStack = new Stack<Integer>();
        minStack.push(Integer.MAX_VALUE);
    }
    
    public void push(int x) {
        xStack.push(x);
        minStack.push(Math.min(minStack.peek(), x));
    }
    
    public void pop() {
        xStack.pop();
        minStack.pop();
    }
    
    public int top() {
        return xStack.peek();
    }
    
    public int getMin() {
        return minStack.peek();
    }
相关推荐
2301_800256114 小时前
地理空间数据库中的CPU 和 I/O 开销
数据库·算法·oracle
一个不知名程序员www4 小时前
算法学习入门---结构体和类(C++)
c++·算法
阿亮爱学代码6 小时前
Java 面试 (三)
面试·职场和发展
XFF不秃头7 小时前
力扣刷题笔记-旋转图像
c++·笔记·算法·leetcode
王老师青少年编程7 小时前
csp信奥赛C++标准模板库STL案例应用3
c++·算法·stl·csp·信奥赛·lower_bound·标准模版库
有为少年8 小时前
Welford 算法 | 优雅地计算海量数据的均值与方差
人工智能·深度学习·神经网络·学习·算法·机器学习·均值算法
Ven%8 小时前
从单轮问答到连贯对话:RAG多轮对话技术详解
人工智能·python·深度学习·神经网络·算法
山楂树の8 小时前
爬楼梯(动态规划)
算法·动态规划
谈笑也风生8 小时前
经典算法题型之复数乘法(二)
开发语言·python·算法