力扣 155. 最小栈||剑指 Offer 30. 包含 min 函数的栈(刷题笔记)

定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的 min 函数在该栈中,调用 min、push 及 pop 的时间复杂度都是 O(1)

class MinStack {
public:
    stack<int> stk,stk_min;
    MinStack() {}
    
    void push(int val) {
        if(stk.empty()){
            //stk空,那么stk_min一定还没有值输入
            stk.push(val);
            stk_min.push(val);
        }
        else{
            stk.push(val);
            //现在两个栈都有值,只需要比较新加入的值和stk_min的栈顶元素大小即可
            //如果输入值小于stk_min栈顶,则将该值压栈
            //如果输入值不于stk_min栈顶,则将stk_min栈顶再次压栈
            stk_min.push(val<stk_min.top()?val:stk_min.top());
            // if(B.top()<x){
            //     B.push(B.top());
            // }
            // else{
            //     B.push(x);
            // }
        }
    }
    
    void pop() {
        //连个栈都要出栈
        stk.pop();
        stk_min.pop();
    }
    
    int top() {
        return stk.top();
    }
    
    int getMin() {
        return stk_min.top();
    }
};

/**
 * 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();
 */

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黑化草莓熊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值