包含min函数的栈

https://ac.nowcoder.com/acm/problem/3707

题目描述

设计一个支持push,pop,top等操作并且可以在O(1)时间内检索出最小元素的堆栈。

  • push(x)–将元素x插入栈中
  • pop()–移除栈顶元素
  • top()–得到栈顶元素
  • getMin()–得到栈中最小元素

样例

MinStack minStack = new MinStack();
minStack.push(-1);
minStack.push(3);
minStack.push(-4);
minStack.getMin();   --> Returns -4.
minStack.pop();
minStack.top();      --> Returns 3.
minStack.getMin();   --> Returns -1.

算法1

(双栈)

我们定义两个栈,一个是正常的栈stk1,另一个是stk2,stk2的栈顶表示当前stk1从栈顶到栈底元素中的最小值

正常的push pop get_top操作由stk1完成

get_min由stk2完成

如何维护stk2

每次进行push操作时,将新加入的元素x与stk2栈顶元素进行比较如果x更小则在stk2中push一个x,否则push一个stk2的栈顶元素

pop操作stk1和stk2同时进行

(实际操作的时候只需要将小于等于stk2.top()的元素push到stk2。如果当前pop的元素和stk2.top()元素相同则stk2.pop()

时间复杂度

C++ 代码

class Solution {
public:
    stack<int> stk1;
    stack<int> stk2;
    Solution() {

    }
    void push(int value) {
        stk1.push(value);
        if(stk2.empty() || stk2.top() >= value)
            stk2.push(value);
    }
    void pop() {
        if(stk2.top() == stk1.top()) stk2.pop();
        stk1.pop();
    }
    int top() {
        return stk1.top();
    }
    int min() {
        return stk2.top();
    }
};

墙裂推荐lyd大佬的书!!!!一起来交流学习这本书吧!!!!

全部评论

相关推荐

11-02 09:49
已编辑
货拉拉_测试(实习员工)
热爱生活的仰泳鲈鱼求你们别卷了:没事楼主,有反转查看图片
点赞 评论 收藏
分享
11-09 14:54
已编辑
华南农业大学 产品经理
大拿老师:这个简历,连手机号码和照片都没打码,那为什么关键要素求职职位就不写呢? 从上往下看,都没看出自己到底是产品经理的简历,还是电子硬件的简历? 这是一个大问题,当然,更大的问题是实习经历的描述是不对的 不要只是去写实习流程,陈平,怎么去开会?怎么去讨论? 面试问的是你的产品功能点,是怎么设计的?也就是要写项目的亮点,有什么功能?这个功能有什么难处?怎么去解决的? 实习流程大家都一样,没什么优势,也没有提问点,没有提问,你就不得分 另外,你要明确你投的是什么职位,如果投的是产品职位,你的项目经历写的全都是跟产品无关的,那你的简历就没用 你的面试官必然是一个资深的产品经理,他不会去问那些计算机类的编程项目 所以这种四不像的简历,在校招是大忌
点赞 评论 收藏
分享
1 收藏 评论
分享
牛客网
牛客企业服务