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();
 */
相关推荐
QiLinkOS5 小时前
第三视觉理解徐玉生与他的商业活动(30)
大数据·c++·人工智能·算法·开源协议
疯狂打码的少年6 小时前
【操作系统】页面置换算法(OPT/FIFO/LRU)
算法
小O的算法实验室6 小时前
2026年CIE,优化客货协同运输:综合地铁系统的列车容量动态分配
算法
Coder_Shenshen7 小时前
西门子S7CommPlus协议鉴权算法原理与流程详解
网络·后端·算法
硕风和炜8 小时前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集
我是一颗柠檬9 小时前
【Java项目技术亮点】加权轮询负载均衡算法
java·算法·负载均衡
灯厂码农9 小时前
C语言动态内存分配完全指南(malloc、calloc、realloc、free)
java·c语言·算法
凯瑟琳.奥古斯特10 小时前
K次取反最大化数组和解法(力扣1005)
开发语言·c++·算法·leetcode·职场和发展
Jerry10 小时前
LeetCode 203. 移除链表元素
算法
地平线开发者11 小时前
征程 6 | 工具链 QAT ObserverBase 源码解析
算法