LeetCode:0302. 栈的最小值(栈 Java)

目录

[0302. 栈的最小值](#0302. 栈的最小值)

题目描述:

实现代码与解析:

原理思路:


0302. 栈的最小值

题目描述:

请设计一个栈,除了常规栈支持的pop与push函数以外,还支持min函数,该函数返回栈元素中的最小值。执行push、pop和min操作的时间复杂度必须为O(1)。

示例:

复制代码
MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin();   --> 返回 -3.
minStack.pop();
minStack.top(); --> 返回 0.
minStack.getMin(); --> 返回 -2.

实现代码与解析:

java 复制代码
//请设计一个栈,除了常规栈支持的pop与push函数以外,还支持min函数,该函数返回栈元素中的最小值。执行push、pop和min操作的时间复杂度必须为O(
//1)。 
// 示例: MinStack minStack = new MinStack(); minStack.push(-2); minStack.push(0); 
//minStack.push(-3); minStack.getMin();   --> 返回 -3. minStack.pop(); minStack.top(
//); --> 返回 0. minStack.getMin(); --> 返回 -2. 
//
// Related Topics 栈 设计 👍 102 👎 0


import java.util.Stack;

//leetcode submit region begin(Prohibit modification and deletion)
class MinStack {
    Stack<Integer> stk1 = new Stack();
    Stack<Integer> stk2 = new Stack();
    /** initialize your data structure here. */
    public MinStack() {
        stk1 = new Stack();
        stk2 = new Stack();
        stk2.push(Integer.MAX_VALUE);
    }
    
    public void push(int x) {
        stk1.push(x);
        stk2.push(Math.min(stk2.peek(), x));
    }
    
    public void pop() {
        stk1.pop();
        stk2.pop();
    }
    
    public int top() {
        Integer peek = stk1.peek();
        return peek;
    }
    
    public int getMin() {
        Integer peek = stk2.peek();
        return 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();
 */
//leetcode submit region end(Prohibit modification and deletion)

原理思路:

简单题,定义一个辅助栈,记录每个状态的最小值即可。

相关推荐
DKPT3 分钟前
ZGC和G1收集器相比哪个更好?
java·jvm·笔记·学习·spring
稚辉君.MCA_P8_Java4 分钟前
通义 插入排序(Insertion Sort)
数据结构·后端·算法·架构·排序算法
n***F87511 分钟前
修改表字段属性,SQL总结
java·数据库·sql
q***697714 分钟前
【Spring Boot】统一数据返回
java·spring boot·后端
Hollis Chuang16 分钟前
Spring Boot 4.0 正式发布,人麻了。。。
java·spring boot·后端·spring
Moshow郑锴38 分钟前
实战分享:用 SpringBoot-API-Scheduler 构建 API 监控闭环 —— 从断言验证到智能警报
java·spring boot·后端·任务调度
无限进步_43 分钟前
C语言动态内存的二维抽象:用malloc实现灵活的多维数组
c语言·开发语言·数据结构·git·算法·github·visual studio
掘我的金1 小时前
播放器最怕“首帧黑屏”?我给 LibreTV 加了一套缓冲与预加载策略
java
Swift社区1 小时前
LeetCode 432 - 全 O(1) 的数据结构
数据结构·算法·leetcode
逝玄1 小时前
关于图灵停机问题不可判定性证明
算法·计算机科学