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

记录算法笔记(2025.5.29)最小栈

设计一个支持 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
  • poptop 和 getMin 操作总是在 非空栈 上调用
  • pushpoptop, and getMin最多被调用 3 * 104 次

思路:可以搞两个栈,一个正常,一个从大到小排序的栈,栈顶为当前最小值,用空间换时间

代码:C#

public class MinStack {

     Stack<int> stack;

     Stack<int> minStack;

    public MinStack() {

        stack=new Stack<int>();

        minStack=new Stack<int>();

    }

   

    public void Push(int val) {

        stack.Push(val);

        if(minStack.Count==0 ||val<=minStack.Peek())//如果记录最小值的栈为空或者入栈的值小于等于最小栈的栈顶,即这个要入栈的值为新一个最小值,也要将它入到记录最小值的栈

        {

            minStack.Push(val);

        }

    }

   

    public void Pop() {

        int val=stack.Pop();

        if(val==minStack.Peek())//如果出栈的值等于记录最小值的栈,则也要出栈

        {

            minStack.Pop();

        }

    }

   

    public int Top() {

        return stack.Peek();

    }

   

    public int GetMin() {

        return minStack.Peek();

    }

}

http://www.lryc.cn/news/2392481.html

相关文章:

  • Android SurfaceFlinger核心工作机制
  • Golang|etcd服务注册与发现 策略模式
  • 深度解析UniApp盲盒系统开发:从源码架构到多端部署全流程
  • STM32的OLED显示程序亲测可用:适用于多种场景的稳定显示解决方案
  • 【AI News | 20250529】每日AI进展
  • Day12 - 计算机网络 - HTTP
  • Linux驱动学习笔记(十)
  • 如何优化Elasticsearch的搜索性能?
  • TI dsp FSI (快速串行接口)
  • 责任链模式:构建灵活可扩展的请求处理体系(Java 实现详解)
  • nlp中的频率就是权重吗
  • 融智学“新五常”框架:五维方式的重构与协同
  • wechat-003-学习笔记
  • 【大模型微调】魔搭社区GPU进行LLaMA-Factory微调大模型自我认知
  • 基于MATLAB编程针对NCV检测数据去漂移任务的完整解决方案
  • 【数据结构】哈希表的实现
  • 永磁同步电机控制算法--基于电磁转矩反馈补偿的新型IP调节器
  • RabbitMQ 应用 - SpringBoot
  • 基于递归思想的系统架构图自动化生成实践
  • OpenGL Chan视频学习-9 Index Buffers inOpenGL
  • 《基于AIGC的智能化多栈开发新模式》研究报告重磅发布! ——AI重塑软件工程,多栈开发引领未来
  • 热门大型语言模型(LLM)应用开发框架
  • Nginx安全防护与HTTPS部署实战
  • JAVA重症监护系统源码 ICU重症监护系统源码 智慧医院重症监护系统源码
  • 静态资源js,css免费CDN服务比较
  • 组合型回溯+剪枝
  • python:机器学习(KNN算法)
  • 【笔记】2025 年 Windows 系统下 abu 量化交易库部署与适配指南
  • 小程序 - 视图与逻辑
  • ChatGPT Plus/Pro 订阅教程(支持支付宝)