[LeetCode] 155. 最小栈

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

实现 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.

解题思路:

这题使用两个栈,可以轻松解决

一个是正常放数据的栈一个是放最小值的栈

这里最关键的是如果放入正常栈的值和最小栈中的栈顶元素相等也需要入最小栈,因为_st出栈的时候可能会出两个相同的最小值,就会出问题

代码实现:

cpp 复制代码
class MinStack {
public:
    //都是自定义类型不需要去手动构造
    MinStack() {}
    
    void push(int val) {
        _st.push(val);

        if(_minst.empty() || _minst.top() >= val)
        {
            _minst.push(val);
        }
    }
    
    void pop() {
        if(_minst.top() == _st.top())
        {
            _minst.pop();
        }

        _st.pop();
    }
    
    int top() {
        return _st.top();
    }
    
    int getMin() {
        return _minst.top();
    }

    stack<int> _st;
    stack<int> _minst;
};
相关推荐
WongKyunban几秒前
使用Valgrind检测内存问题(C语言)
c语言·开发语言
Bin二叉几秒前
南京大学cpp复习——第二部分(继承)
开发语言·c++·笔记·学习
代码游侠3 分钟前
数据结构——线性表
linux·c语言·数据结构·学习·算法
潼心1412o4 分钟前
数据结构(长期更新)第10讲:堆
数据结构
吃着火锅x唱着歌5 分钟前
LeetCode 3371.识别数组中的最大异常值
数据结构·算法·leetcode
元亓亓亓7 分钟前
LeetCode热题100--74. 搜索二维矩阵--中等
算法·leetcode·矩阵
dringlestry9 分钟前
B树的最大/最小高度
数据结构·b树
橘子编程10 分钟前
仓颉语言:华为新一代编程利器
java·c语言·开发语言·数据库·python·青少年编程
lingggggaaaa18 分钟前
免杀对抗——C2远控篇&PowerShell&C#&对抗AV-EDR&停用AMSI接口&阻断ETW跟踪&调用
c语言·开发语言·c++·学习·安全·c#·免杀对抗
zzzsde18 分钟前
【C++】异常:概念及使用
开发语言·c++·算法