Leetcode155. 最小栈(HOT100)

链接

代码:

cpp 复制代码
class MinStack {
private:
    stack<int> f,s;
public:
    MinStack(){}
    
    void push(int val) {
        s.push(val);
        if(f.empty()||val<=f.top()){
            f.push(val);
        }
    }
    
    void pop() {
        if(s.top()<=f.top())f.pop();
        s.pop();
    }
    
    int top() {
        return s.top();
    }
    
    int getMin() {
        return f.top();
    }
};

题解:这个题意还是比较难懂,代码写起来很简单,我们定义类的私有变量s作为存储数据的栈,然后为了常数时间内返回栈中最小元素,所以我们还定义了一个栈 f。f[i] 即:与之对应的s栈中目前最小的元素,但是我们还做了一个优化:如果你push进s栈一个很大的元素,我们 f 栈没必要动弹,因为我们f 记录的是最小元素。怎么判断?你push进s栈的元素如果小于等于f 的栈顶,我才在f 栈加一个元素。否则我f 栈什么都不做。

pop的时候也一样,pop的元素如果大于我的栈顶元素,那f 栈就不必更新什么。反之,如果你pop的元素小于等于f 栈顶元素,那么说明我之前记录过,所以f 也要pop。

相关推荐
田梓燊40 分钟前
湘潭大学软件工程算法设计与分析考试复习笔记(六)
笔记·算法·软件工程
重生之Java开发工程师1 小时前
算法笔记:前缀和
笔记·算法
sweetheart7-71 小时前
LeetCode155. 最小栈(2024冬季每日一题 12)
算法··模拟栈·最小元素
藏鹤虞渊1 小时前
【ONE·基础算法 || 动态规划(二)】
算法·动态规划
kcwqxx2 小时前
day23|leetCode 39. 组合总和 , 40.组合总和II , 131.分割回文串
c++·算法·leetcode
一颗青果2 小时前
【Linux】详解shell代码实现(上)
linux·运维·服务器·前端·chrome·算法·1024程序员节
Best_Me072 小时前
快速排序算法-C语言
c语言·算法·排序算法
Tianwen_Burning3 小时前
halcon3D 1:1切片轮廓投影技术,透过像素距离,知实际物体的尺寸
算法·3d
pursuit_csdn3 小时前
LeetCode 1072. Flip Columns For Maximum Number of Equal Rows
数据结构·算法·leetcode·力扣