力扣hot100:155. 最小栈(栈,辅助栈存储相关信息)

LeetCode:155. 最小栈

1、尝试单调栈

看到这题说,要常数时间内检索最小元素的栈,想到了单调栈,递增单调栈确实能维护最小值,但是这个最小值是存在一定意义的,即如果后面出现了最小值,那么前面的之前的最小值就会无效。

而本题存在弹出操作,这导致当前最小值可能会被丢弃,而需要使用之前的最小值,单调栈可能无法做到找回次小值。

能够弹出值且能一直保持维护数据的最小值的数据结构,是优先队列。因此我们改用优先队列实现。

2、栈+优先队列

如果想要常数级检索到最小元素 且 存在弹出元素,那么需要自定义优先队列,这时在弹出时时间复杂度会高一些。如果不自定义,那就需要延迟出队,这样虽然获取最小值时时间复杂度为高一些,但是弹出时间比较小。

  • 时间复杂度: O ( n l o g n ) O(nlogn) O(nlogn),堆排序的时间复杂度
  • 空间复杂度: O ( n ) O(n) O(n)
cpp 复制代码
class MinStack {
public:
    MinStack() {}
    
    void push(int val) {
        sta.push(val);
        nums[val]++;
        minSta.push(val);
    }
    
    void pop() {
        int num = sta.top();
        sta.pop();
        if(--nums[num] == 0) nums.erase(num);
    }
    
    int top() {
        return sta.top();
    }
    
    int getMin() {
        while(nums.count(minSta.top()) == 0) minSta.pop();
        return minSta.top();
    }
private:
    stack<int> sta;
    priority_queue<int, vector<int>, greater<int>> minSta;
    unordered_map<int, int> nums;
};

3、辅助栈

方法二,我们使用优先队列实时维护最小值,有必要吗?

要是我们直接使用一个栈为每一个元素维护一个以它为栈顶的栈的最小值,那是不是就OK了?

即:只要栈顶元素确定了,那么栈中当前的最小值也必然是唯一确定的。我们只需要维护一个元素时最小值的栈就行。

  • 时间复杂度: O ( n ) O(n) O(n),插入只需压栈两次,pop只需弹栈两次,查询是 O ( 1 ) O(1) O(1)
  • 空间复杂度: O ( n ) O(n) O(n)
cpp 复制代码
class MinStack {
public:
    MinStack() {
        min_sta.push(INT_MAX);//这个只是为了方便后面压入少一个条件判断
    }
    
    void push(int val) {
        sta.push(val);
        min_sta.push(min(min_sta.top(),val));
    }
    
    void pop() {
        sta.pop();
        min_sta.pop();
    }
    
    int top() {
        return sta.top();
    }
    
    int getMin() {
        return min_sta.top();
    }
private:
    stack<int> sta;
    stack<int> min_sta;
};
相关推荐
格林威22 分钟前
常规线扫描镜头有哪些类型?能做什么?
人工智能·深度学习·数码相机·算法·计算机视觉·视觉检测·工业镜头
007php0071 小时前
某大厂跳动面试:计算机网络相关问题解析与总结
java·开发语言·学习·计算机网络·mysql·面试·职场和发展
程序员莫小特2 小时前
老题新解|大整数加法
数据结构·c++·算法
过往入尘土3 小时前
服务端与客户端的简单链接
人工智能·python·算法·pycharm·大模型
zycoder.3 小时前
力扣面试经典150题day1第一题(lc88),第二题(lc27)
算法·leetcode·面试
Dream it possible!4 小时前
LeetCode 面试经典 150_哈希表_存在重复元素 II(46_219_C++_简单)
leetcode·面试·散列表
蒙奇D索大4 小时前
【数据结构】考研数据结构核心考点:二叉排序树(BST)全方位详解与代码实现
数据结构·笔记·学习·考研·算法·改行学it
智驱力人工智能4 小时前
工厂抽烟检测系统 智能化安全管控新方案 加油站吸烟检测技术 吸烟行为智能监测
人工智能·算法·安全·边缘计算·抽烟检测算法·工厂抽烟检测系统·吸烟监测
学学学无无止境4 小时前
组合两个表-力扣
leetcode
程序员爱钓鱼5 小时前
Go语言实战案例——进阶与部署篇:编写Makefile自动构建Go项目
后端·算法·go