当前位置: 首页 > article >正文

Leetcode每日刷题之155.最小栈

1.题目解析

本题是实现一个栈并且要实现其中的插入、删除、返回栈顶元素、返回最小元素的函数,这里主要的难点就是返回最小元素的函数,如果我们直接遍历,那么时间复杂度就是O(N),但是题目要求我们需要在常数时间也就是O(1)的时间复杂度内实现,那么接下来我们使用一种巧妙地方法来完成本题

 

2.算法原理

这里的主要难点只有在常数时间内找出栈顶最小元素,我们可以创建一个minst栈来存储数据,具体原理是在向st插入数据时判断此时插入的数据与minst中的栈顶元素哪个更小,如果minst的栈顶元素更小则st继续插入,反之则将该较小值插入minst的栈顶即可,注意重复数字也需要插入,因为st删除数据时如果此时st与minst的栈顶元素相同则需要同时删除,最后minst栈顶的元素就是st栈中的最小值,此时直接返回minst.top()即可

 

3.代码展示

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();
    }

private:
    stack<int> st;
    stack<int> minst;
};

/**
 * 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();
 */

 


http://www.kler.cn/a/291944.html

相关文章:

  • 2.STM32之通信接口《精讲》之USART通信
  • 走进嵌入式开发世界
  • SpringCloud篇(服务网关 - GateWay)
  • LeetCode题解:18.四数之和【Python题解超详细】,三数之和 vs. 四数之和
  • 【操作系统实验课】Makefile与编译
  • 在Node.js中如何使用TypeScript
  • FPGA——VGA协议
  • 【Redis】深入解析 Redis 事务:特性、操作及其与 MySQL 事务的区别
  • Fiddler安卓设备抓包基础
  • ffmpeg音视频开发从入门到精通——ffmpeg下载编译与安装
  • iOS App快捷指令(App Intents)在系统搜索服务中注册shortcuts
  • Monkey日志ANR、CRASH、空指针异常及其他异常数据分析
  • 文件夹图标工具类 - C#小函数类推荐
  • JS中的【Symbol】全面讲解
  • 启动spring boot项目时,第三方jar包扫描不到的问题。
  • 编程效率革命:智能工具与自动化脚本的完美结合
  • 144. 腾讯云Redis数据库
  • MOM成功实施分享(三)数字化项目落地蓝图经验分享
  • 2024 高教社杯 数学建模国赛 (B题)深度剖析|生产过程中的决策问题|数学建模完整代码+建模过程全解全析
  • echarts多个环形图
  • Linux 进程与线程相关函数及进程间通信方法
  • 基于微信小程序的挂号管理系统-web管理端
  • 酒店预约小程序搭建,让酒店更加智能化
  • SQLite 创建表:一场数据库里的“造物运动”
  • controlnet reference only
  • 微信小程序:如何在实现页面之间的返回