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

LeetCode[中等] 155. 最小栈

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

实现 MinStack 类:

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

 思路:

若栈中元素为 b c d,a进栈,则只要a在栈中,b c d 就一定在栈中(a出栈之前,b c d 一定不会出栈),因此,a为栈顶一定对应一个最小元素

利用辅助栈,将元素栈同步插入与删除,用于存储与每个元素对应的最小值:

  • 栈顶存储栈内最小元素
  • 新元素入栈时,将当前辅助栈的栈顶存储的最小值 与 当前元素进行比较,从而更新栈顶最小值
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(minStack.Peek());}elseminStack.Push(val);}public void Pop() {stack.Pop();minStack.Pop();}public int Top() {return stack.Peek();}public int GetMin() {return minStack.Peek();}
}

复杂度分析

  • 时间复杂度:构造方法和每一项操作的时间复杂度都是 O(1)。
  • 空间复杂度:O(n),其中 n 是元素个数。空间复杂度主要取决于栈空间,常规栈和最小元素栈的空间都是 O(n)。
http://www.lryc.cn/news/443853.html

相关文章:

  • Python青少年简明教程目录
  • Revit学习记录-版本2018【持续补充】
  • 深度学习01-概述
  • leetcode232. 用栈实现队列
  • 智慧火灾应急救援航拍检测数据集(无人机视角)
  • eureka.client.service-url.defaultZone的坑
  • 统信服务器操作系统【d版字符系统升级到dde图形化】配置方法
  • 学习IEC 62055付费系统标准
  • 如何在Markdown写文章上传到wordpress保证图片不丢失
  • html,css基础知识点笔记(二)
  • (k8s)kubernetes 部署Promehteus学习之路
  • 初写MySQL四张表:(3/4)
  • 【Java】线程暂停比拼:wait() 和 sleep()的较量
  • CQRS模型解析
  • qt-C++笔记之作用等同的宏和关键字
  • java(3)数组的定义与使用
  • Integer 源码记录
  • 【RocketMQ】一、基本概念
  • 笔记9.18
  • 时间序列8个基准Baseline模型及其详细解读
  • 将相机深度图转接为点云的ROS2功能包
  • 计算机毕业设计选题推荐-共享图书管理系统-小程序/App
  • 架构师:在 Spring Cloud 中实现全局异常处理的技术指南
  • es由一个集群迁移到另外一个集群es的数据迁移
  • java项目之常规应急物资管理系统(源码+文档)
  • text2sql方法:RESDSQL和DAIL-SQL
  • Stable Diffusion 优秀博客转载
  • 探索IT行业的无限潜力:技术、发展与职业前景
  • ESP32配网接入Wifi
  • 前端-js例子:收钱转账