LeetCodeHot100——155.最小栈

题目链接放在这里了:155. 最小栈 - 力扣(LeetCode)

这道题的思路就是要我们实现一个最小栈和它的基本几个功能,最小栈就是在一个栈的基础上,可以让我们知道这个栈任意时刻的最小值。我最初是想在一个栈的基础上加上一个属性用来存储最小值,如果你也这么想那么你就想的太简单了,如果栈里有5个元素,最小值肯定是确定了呗,那如果我们这时候pop了呢,那下一个最小值怎么确认?,难道还要存储倒数第二小的做备份吗,那倒数第二小的就不用更新了吗,依次往复我们是不是要记录从开始到结尾每个元素在栈顶时对应的最小值啊,那这样的话我们是不是就可以搞一个同步队列啊,根据栈里的对应关系,记录每个位置对应的最小值,这样是可以实现的,还有就是我们可以通过数组或者map的形式,我们的栈中存储的不再是简单的一个数字了,而是多个map或者多个大小为2的小数组,这样我们在push的时候,如果栈为空那就直接push(value,value),如果不为空那就peek()一下前一个的最小值,和这次要push的值做比较,取较小值作为当前值对应的最小值,这种思路下来我们在查看最小值的时候只需要peek然后查看最小值对应位置的元素就好了,这样栈中的每个元素都有其在栈顶时刻的最小值和value了;

下面是我的方法,我是使用了map,主要是想熟悉一下map的api,在我们不知道key值的时候想按序获取map的Key和Value使用map.entrySet().iterator().next().getValue()/getKey()来操作;

java 复制代码
class MinStack {
    private Deque<Map<Integer,Integer>> stack;
    public MinStack() {
        stack = new LinkedList<>();
    }
    
    public void push(int value) {
        Map<Integer,Integer> cur = new HashMap<>();
        if(stack.isEmpty()){
            cur.put(value,value);
        }else{
            int t = stack.peek().entrySet().iterator().next().getValue();
            cur.put(value,Math.min(value,t));
        }
        stack.push(cur);
    }
    
    public void pop() {
        if(!stack.isEmpty()){
            stack.pop();
        }
    }
    
    public int top() {
        return stack.peek().entrySet().iterator().next().getKey();
    }
    
    public int getMin() {
        return stack.peek().entrySet().iterator().next().getValue();
    }
}

/**
 * Your MinStack object will be instantiated and called as such:
 * MinStack obj = new MinStack();
 * obj.push(value);
 * obj.pop();
 * int param_3 = obj.top();
 * int param_4 = obj.getMin();
 */
相关推荐
x138702859571 天前
c语言中srtlen(指针使用计算字符长度)、传值和传址调用
c语言·开发语言·算法·visual studio
海兰1 天前
【实用程序】电商销售分析仪表盘 — 从零搭建一个AI参与的全栈数据洞察系统
人工智能·学习·算法
zwenqiyu1 天前
P5283 [十二省联考 2019] 异或粽子题解
c++·学习·算法
wayz111 天前
Momentum:TSI(真实强度指数)技术指标详解
算法·金融·数据分析·量化交易·特征工程
万事大吉CC1 天前
Python 笔试输入模板总结
python·算法
lihao lihao1 天前
Linux信号
开发语言·c++·算法
大白话_NOI1 天前
【洛谷 P2249】查找(深基 13. 例 1)+ 详细分析
c++·算法
吠品1 天前
C++实现m行n列带边框的长方形输出
算法
智者知已应修善业1 天前
【51单片机2个外部中断显示中断历时,初始化8左移3位共阳数码管】2024-6-6
c++·经验分享·笔记·算法·51单片机
西安邮电大学1 天前
分治算法详细讲解
java·后端·其他·算法·面试