hot100-56最小栈

一、题目

实现最小栈类,栈+获取栈中最小元素。

push(int val)将元素val推入栈中,pop()删除栈中顶部的元素,

top()获取栈中顶部的元素,getMin()获取栈中最小元素。

二、思路

1、普通的栈可以实现push、pop、top,都是O(1),而找最小值要遍历整个栈,并且getMin()也要求O(1),所以不能临时计算,要利用一个主栈存储所有入栈的原始数据,同时维护一个最小值栈(栈顶始终是主栈中的最小值)。

2、push(val)时,如果 val 小于或等于 minStack 的栈顶(当前最小值),就把 val 也压入 minStack。

pop()时,如果弹出的元素等于 minStack 的栈顶,说明当前最小值被移除了,也要从 minStack弹出。

三、代码

复制代码
class MinStack {
    private Deque<Integer> stack;
    private Deque<Integer> minStack;
    public MinStack() {
        stack = new ArrayDeque<>();
        minStack = new ArrayDeque<>();
    }
    
    public void push(int val) {
        stack.push(val);
        if(minStack.isEmpty() || val <= minStack.peek()){
            minStack.push(val);
        }
    }
    
    public void pop() {
        int top = stack.pop();
        if(top == minStack.peek()){
            minStack.pop();
        }
        
    }
    
    public int top() {
        return stack.peek();
        
    }
    
    public int getMin() {
        return minStack.peek();
    }
}

/**
 * Your MinStack object will be instantiated and called as such:
 * MinStack obj = new MinStack();
 * obj.push(val);
 * obj.pop();
 * int param_3 = obj.top();
 * int param_4 = obj.getMin();
 */

四、语法记录一下

1)Deque<Integer> stack = new ArrayDeque<>();推荐

Deque双端队列,支持栈操作 push() pop() peek()

2)Stack<Integer> stack = new Stack<>();不推荐

3)入栈

stack.push(x)

4)出栈

stack.pop()

5)查看栈顶

stack.peek()

6)判断空

stack.isEmpty() 返回true/false

7)大小

stack.size() 返回元素个数

相关推荐
Cthy_hy9 小时前
并查集(Disjoint Set Union):巧判「连通聚类关系」的极简利器
数据结构·算法
阿Y加油吧10 小时前
两道位运算 / 摩尔投票经典题复盘:只出现一次的数字 & 多数元素
数据结构·算法·leetcode
05候补工程师10 小时前
【408狂飙·数据结构】核心考点深度复盘:数组地址计算、特殊矩阵压缩存储与树的五大性质解题直觉
数据结构·笔记·线性代数·考研·算法·矩阵
炘爚11 小时前
数据结构:顺序表
数据结构
LuminousCPP11 小时前
数据结构 - 线性表第二篇:动态顺序表进阶接口实现
c语言·数据结构·笔记·顺序表·线性表
承渊政道11 小时前
【贪心算法】(经典实战应用解析(五):单调递增的数字、坏了的计算器、合并区间、⽆重叠区间、⽤最少数量的箭引爆⽓球)
数据结构·c++·leetcode·贪心算法·排序算法·动态规划·哈希算法
念恒1230612 小时前
Python(while循环)
数据结构·python·算法
bqq1986102612 小时前
Redis持久化
数据结构·数据库·redis·缓存
阳明山水13 小时前
模型迭代实战:如何将准确率从75%提升到89%
数据结构·人工智能·算法·机器学习·微信·微信公众平台·微信开放平台
故事和你9114 小时前
洛谷-【图论2-2】最短路4
开发语言·数据结构·c++·算法·动态规划·图论