LeetCode: Min Stack最小值栈

睡不着,起来写道题

言归正传:

  • 其实这道题很简单,不过我之前腾讯的实习生面试的时候还遇到过这道题,所以还是可以做做,其实最主要的思路就是一点,创建一个新的栈min用来记录在当前状态下本来那个栈stk的最小值.最小值就是min栈的栈顶。
class MinStack {
public:
    stack<int> stk;
    stack<int> min;
    void push(int x) {
        stk.push(x);
        if(min.empty() || x<=min.top())
        {
            min.push(x);
        }
    }

    void pop() {
        if(min.top() == stk.top()) 
        {
            min.pop();
        }
        stk.pop();
    }

    int top() {
       return stk.top();
    }

    int getMin() {
        return min.top();
    }
};
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,025评论 25 709
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,357评论 0 33
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,595评论 18 399
  • 20170924 第十组李文艳 #只有感觉好才会做得好!# 孩子第一个30天目标:在30分钟内吃完饭 妈妈第一个3...
    文子16阅读 1,130评论 0 0
  • 事件是中立的,好坏是非对错,不是取决于事件本身,而是取决于观察者,取决于观察者对它的看法!看法决定做法,做法决定...
    安清King阅读 5,805评论 0 5

友情链接更多精彩内容