LeetCode 面试经典150题 [52/150 最小栈]


avatar
GuoYulong 2024-06-28 68

题目描述

设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。

实现 MinStack 类:

MinStack() 初始化堆栈对象。
void push(int val) 将元素val推入堆栈。
void pop() 删除堆栈顶部的元素。
int top() 获取堆栈顶部的元素。
int getMin() 获取堆栈中的最小元素。
示例 1:

["MinStack","push","push","push","getMin","pop","top","getMin"]
[[],[-2],[0],[-3],[],[],[],[]]

输出:
[null,null,null,null,-3,null,0,-2]

解释:
MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin();   --> 返回 -3.
minStack.pop();
minStack.top();      --> 返回 0.
minStack.getMin();   --> 返回 -2.

个人C++解答


看评论区好像这道题经常出现在面试题中,按照官方的思路是创建两个栈来完成任务,一个栈提供所有的数据进行入栈出栈和栈顶数据查找的功能,另一个栈提供最小元素查找的功能,由于有出入栈的操作,所以对于最小栈,入栈的是最小的元素,即当前数据和栈顶数据的最小值作为新元素入栈,这样能够保证入栈后出栈元素是最小值的话那就正常出栈,不是最小值的话不影响最小栈的查找;
但是这种思路其实可以说是作弊了,毕竟这道题是要模拟一个栈的操作,如果用栈来模拟栈的话,可能面试官并不会喜欢?

GYL
class MinStack {
private:
    stack<int> stk;
    stack<int> minstk;
public:
    MinStack() {
        minstk.push(INT_MAX);
    }
    
    void push(int val) {
        stk.push(val);
        minstk.push(min(minstk.top(),val));
    }
    
    void pop() {
        stk.pop();
        minstk.pop();
    }
    
    int top() {
        return stk.top();
    }
    
    int getMin() {
        return minstk.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();
 */

相关阅读

注意!!!

新增会员中心页面,方便管理个人账户,充值功能暂不开启,请勿为本网站进行任何充值活动!!!

通知!!!

① 过年好!!!拖更几个月了已经,年后继续更新!!