LeetCode热题100 最小栈

题目描述

设计一个支持 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.

提示:

−231<=val<=231−1-2^{31} <= val <= 2^{31} - 1−231<=val<=231−1

pop、top 和 getMin 操作总是在 非空栈 上调用

push, pop, top, and getMin最多被调用 3∗1043 * 10^43∗104 次

思路

手写一个栈+最小前缀和。

代码

cpp 复制代码
struct node{
    node(int value, int min_value, node *next) : _value(value), _min_value(min_value), _next(next){}
    int _value;
    int _min_value;
    node* _next;
};

class MinStack {
public:
    MinStack()
    {
        _top = nullptr;
    }
    
    void push(int val)
    {
        node *cur = new node(val, val, nullptr);
        if(_top == nullptr)
        {
            _top = cur;
        }
        else
        {
            cur->_next = _top;
            cur->_min_value = min(cur->_min_value, _top->_min_value);
            _top = cur;
        }
    }
    
    void pop()
    {
        node *cur = _top;
        _top = _top->_next;
        delete cur;
    }
    
    int top()
    {
        return _top->_value;    
    }
    
    int getMin()
    {
        return _top->_min_value;
    }

    node *_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();
 */
相关推荐
小小de风呀12 小时前
de风——【从零开始学C++】(五):内存管理
开发语言·c++
Hello.Reader13 小时前
算法基础(十)——分治思想把大问题拆成小问题
java·开发语言·算法
CHANG_THE_WORLD14 小时前
C语言中的 %*s 和 %.*s 和C++的字符串格式化输出
c语言·c++·c#
绛橘色的日落(。・∀・)ノ14 小时前
机器学习之评估与偏差方差分析
算法
消失的旧时光-194314 小时前
C语言对象模型系列(四)《Linux 内核里的 container_of 到底是什么黑魔法?》—— 一篇讲透 Linux 内核的“对象模型”核心技巧
linux·c语言·算法
AI_Ming15 小时前
从0开始学AI:层归一化,原来是这回事!
算法·ai编程
WL_Aurora15 小时前
备战蓝桥杯国赛【Day 8】
算法·蓝桥杯
螺丝钉的扭矩一瞬间产生高能蛋白15 小时前
QT的C++接口基础用法
c++·qt·嵌入式软件·嵌入式linux·linux应用
智者知已应修善业15 小时前
【51单片机模拟生日蜡烛】2023-10-10
c++·经验分享·笔记·算法·51单片机
MediaTea15 小时前
Scikit-learn:从数据到结构——无监督学习的最小闭环
人工智能·学习·算法·机器学习·scikit-learn