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

LeetCode 155. Min Stack 题解

LeetCode 155. Min Stack 题解题目描述设计一个支持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.解题思路方法辅助栈思路使用两个栈一个主栈用于存储所有元素一个辅助栈用于存储当前的最小元素当推入元素时将元素压入主栈并将当前最小元素压入辅助栈当弹出元素时同时弹出主栈和辅助栈的栈顶元素当获取顶部元素时返回主栈的栈顶元素当获取最小元素时返回辅助栈的栈顶元素复杂度分析时间复杂度O(1)所有操作都是常数时间。空间复杂度O(n)需要使用两个栈来存储元素。代码实现方法辅助栈class MinStack: def __init__(self): # 初始化主栈和辅助栈 self.stack [] self.min_stack [] def push(self, val: int) - None: # 将元素压入主栈 self.stack.append(val) # 将当前最小元素压入辅助栈 # 如果辅助栈为空或者当前元素小于等于辅助栈的栈顶元素则压入 if not self.min_stack or val self.min_stack[-1]: self.min_stack.append(val) # 否则再次压入辅助栈的栈顶元素 else: self.min_stack.append(self.min_stack[-1]) def pop(self) - None: # 同时弹出主栈和辅助栈的栈顶元素 if self.stack: self.stack.pop() self.min_stack.pop() def top(self) - int: # 返回主栈的栈顶元素 if self.stack: return self.stack[-1] return None def getMin(self) - int: # 返回辅助栈的栈顶元素 if self.min_stack: return self.min_stack[-1] return None测试用例测试用例 1输入[MinStack,push,push,push,getMin,pop,top,getMin] [[],[-2],[0],[-3],[],[],[],[]]输出[null,null,null,null,-3,null,0,-2]总结本题是栈的经典应用问题主要考察对栈数据结构的理解和使用。通过使用辅助栈我们可以在常数时间内检索到最小元素。辅助栈的核心思想是使用两个栈一个主栈用于存储所有元素一个辅助栈用于存储当前的最小元素当推入元素时将当前最小元素压入辅助栈当弹出元素时同时弹出主栈和辅助栈的栈顶元素。这种方法不仅适用于最小栈问题还可以应用于许多其他需要在常数时间内检索到特定元素的问题。掌握辅助栈的使用对于解决这类问题非常重要。

相关文章:

LeetCode 155. Min Stack 题解

LeetCode 155. Min Stack 题解 题目描述 设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。 实现 MinStack 类: MinStack() 初始化堆栈对象。void push(int val) 将元素 val 推入堆栈。void pop() 删除堆栈…...

实战指南:PZEM-004T v3.0电力监测模块在工业物联网中的高效应用

实战指南:PZEM-004T v3.0电力监测模块在工业物联网中的高效应用 【免费下载链接】PZEM-004T-v30 Arduino library for the Updated PZEM-004T v3.0 Power and Energy meter 项目地址: https://gitcode.com/gh_mirrors/pz/PZEM-004T-v30 PZEM-004T v3.0作为一…...

【C++】原地删除有序数组重复元素:两种解法的深度剖析

一、问题描述题目要求给定一个非严格递增排列的整数数组 nums,需要原地删除重复出现的元素,使得每个元素只出现一次,并返回删除后数组的新长度。具体要求元素的相对顺序必须保持一致返回唯一元素的数量 k数组的前 k 个元素应包含去重后的唯一…...

揭秘Cursor-Free-VIP:如何突破AI编码工具的机器ID限制实现永久免费使用

揭秘Cursor-Free-VIP:如何突破AI编码工具的机器ID限制实现永久免费使用 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve …...

LSPatch实战教程:如何为APK文件嵌入Xposed模块

LSPatch实战教程:如何为APK文件嵌入Xposed模块 【免费下载链接】LSPatch A non-root Xposed framework extending from LSPosed 项目地址: https://gitcode.com/gh_mirrors/lsp/LSPatch LSPatch是一款强大的非Root Xposed框架,源自LSPosed项目&am…...

ant-design-vue Table+Form实现动态表单验证:自定义规则与必填项触发实战

1. 动态表单验证的核心场景 在管理后台开发中,表格内嵌表单的需求非常常见。比如我们需要批量编辑商品信息,或者动态添加多行联系人数据时,传统的做法是在表格外单独做表单,但这样会导致操作流程割裂。ant-design-vue的TableForm组…...

避坑指南:STM32WLE5CCU6移植LoRaWAN节点,搞定BSP报错、信道配置与OTAA入网参数

STM32WLE5CCU6 LoRaWAN节点移植实战:从BSP报错到OTAA入网的完整避坑手册 去年第一次接触STM32WLE5系列芯片时,我花了整整三天时间才让LoRaWAN节点成功入网。期间遇到的BSP缺失、信道配置错误、OTAA参数无效等问题,几乎踩遍了所有新手可能遇到…...

Unity UI布局核心:从RectTransform的localPosition与anchoredPosition看父子坐标系

1. RectTransform基础概念解析 在Unity的UI系统中,RectTransform就像是一个魔法尺子,它不仅能测量UI元素的大小和位置,还能决定这个元素如何"粘"在它的父元素上。想象一下你在布置房间:RectTransform就是那个告诉你&quo…...

【2026年】新大纲普通话考试真题题库50套(PDF电子版)

2026年国家普通话水平测试新大纲及配套资源说明 大纲更新要点 自2024年1月1日起,国家语言文字工作委员会正式实施《普通话水平测试新版大纲》。本次修订对测试内容与形式进行了系统性优化,明确规定了以下核心组成部分: 朗读短文&#xff1…...

终极暗黑2存档编辑器指南:如何快速打造完美游戏角色

终极暗黑2存档编辑器指南:如何快速打造完美游戏角色 【免费下载链接】d2s-editor 项目地址: https://gitcode.com/gh_mirrors/d2/d2s-editor 你是否曾经花费数小时刷装备,结果却一无所获?或是角色属性点分配不当,导致后期…...

VirtualBox 7.0 保姆级教程:手把手教你给Win10虚拟机装“显卡驱动”(增强功能详解)

VirtualBox 7.0 性能优化全攻略:解锁Win10虚拟机的完整潜能 当你第一次在VirtualBox中成功运行Win10虚拟机时,那种兴奋感可能很快会被一些不便所取代——窗口无法自适应缩放、文件传输需要繁琐的共享设置、显示效果总是差强人意。这些问题背后&#xff0…...

Navicat重置脚本终极指南:3种简单方法无限恢复试用期

Navicat重置脚本终极指南:3种简单方法无限恢复试用期 【免费下载链接】navicat_reset_mac navicat mac版无限重置试用期脚本 Navicat Mac Version Unlimited Trial Reset Script 项目地址: https://gitcode.com/gh_mirrors/na/navicat_reset_mac 你是否正在寻…...

保姆级教程:用Helm在K8s上部署RustFS对象存储(含Local Path配置与Ingress暴露)

Kubernetes实战:基于Helm与Local Path的RustFS对象存储部署指南 当企业需要构建私有化对象存储解决方案时,兼容S3协议的开源存储系统成为热门选择。本文将手把手带您完成RustFS在Kubernetes集群中的生产级部署,涵盖从底层磁盘准备到Ingress暴…...

ActiveMQ与微服务架构集成:构建分布式系统通信解决方案

ActiveMQ与微服务架构集成:构建分布式系统通信解决方案 【免费下载链接】activemq Apache ActiveMQ 项目地址: https://gitcode.com/gh_mirrors/ac/activemq Apache ActiveMQ作为一款强大的消息中间件,为微服务架构提供了可靠的异步通信支持&…...

Qwen3.5-9B合规部署:GDPR数据不出境+对话记录加密存储方案

Qwen3.5-9B合规部署:GDPR数据不出境对话记录加密存储方案 1. 项目概述 Qwen3.5-9B是一款拥有90亿参数的开源大语言模型,具备强大的逻辑推理、代码生成和多轮对话能力。该模型支持多模态理解(图文输入)和长上下文处理&#xff08…...

Phi-4-mini-reasoning Chainlit A/B测试:不同系统提示词对推理质量影响分析

Phi-4-mini-reasoning Chainlit A/B测试:不同系统提示词对推理质量影响分析 1. 模型介绍与部署验证 1.1 Phi-4-mini-reasoning模型特点 Phi-4-mini-reasoning是一个专注于高质量推理能力的轻量级开源模型,具有以下核心特性: 推理能力优化…...

Pharos Network联合港大金融科技学院,启动AI决策研究项目,深化Layer1与学术融合

香港,2026年4月15日 —— 专注于机构级别的金融型 Layer 1公链 Pharos Network 宣布,与香港大学渣打慈善基金金融科技学院 共同在香港大学商学院硕士课程Capstone Proiect框架下开展的学术与产业联合研究合作,同时与 Pharos 生态孵化体系形成…...

⚖️Lychee-Rerank效果展示:跨境电商多语言Query(中/英/日)与商品描述匹配案例

Lychee-Rerank效果展示:跨境电商多语言Query与商品描述匹配案例 1. 引言:当搜索遇到多语言难题 想象一下这个场景:你是一家跨境电商平台的运营人员,每天要处理成千上万的商品搜索请求。用户可能用中文搜索“无线蓝牙耳机”&…...

FireRed-OCR Studio惊艳效果:专利文件权利要求书层级结构精准识别

FireRed-OCR Studio惊艳效果:专利文件权利要求书层级结构精准识别 1. 引言:当文档解析遇到专利权利要求书 想象一下,你面前有一份长达几十页的专利文件,其中最关键的部分——权利要求书——采用了复杂的层级结构:独立…...

2026年中国词元经济产业链全景分析报告

2026年以来,AI应用场景持续破圈,从春节AI红包到OpenClaw “全民养虾” 等现象级事件席卷全球,人工智能正式从交互对话走向自主执行的智能体时代,带动行业需求迎来爆发式增长。在此背景下,词元作为 AI 运行与服务交互的…...

别再只会用VLC了!手把手教你用Python+OpenCV调用UVC摄像头(附完整代码)

PythonOpenCV调用UVC摄像头实战指南 在计算机视觉项目中,USB摄像头是最常用的图像采集设备之一。但很多开发者仅仅停留在使用VLC等现成软件查看画面的阶段,没有充分发挥UVC协议提供的丰富控制功能。本文将带你深入探索如何用PythonOpenCV直接调用UVC摄像…...

【实战解析】【立体匹配系列】AD-Census代价计算:从公式到代码的深度剖析

1. AD-Census算法背景与核心思想 AD-Census算法最早由中国学者Xing Mei等人在2011年ICCV会议上提出,这篇名为《On Building an Accurate Stereo Matching System on Graphics Hardware》的论文,为立体匹配领域带来了一个高效且效果出色的解决方案。你可能…...

企业级Nacos定制全攻略:从logo替换到服务地址穿透的完整解决方案

企业级Nacos深度定制实战:打造专属服务发现平台 在数字化转型浪潮中,服务发现组件已成为现代微服务架构的核心基础设施。作为阿里巴巴开源的明星项目,Nacos凭借其服务发现、配置管理和服务治理三位一体的能力,正逐步取代Eureka成…...

ARM Cortex-M开发避坑指南:DMB、DSB、ISB这三个内存屏障指令到底什么时候用?

ARM Cortex-M开发实战:DMB/DSB/ISB内存屏障指令深度解析与避坑指南 在嵌入式开发领域,尤其是基于ARM Cortex-M系列处理器的项目中,内存屏障指令就像交通信号灯一样默默维持着系统运行的秩序。许多工程师虽然知道DMB、DSB、ISB这三个指令的存在…...

如何从零打造一个高性价比的DIY蓝牙音箱?

1. 为什么选择DIY蓝牙音箱? 每次看到商场里动辄上千元的蓝牙音箱,我都会想:这东西真的值这个价吗?拆开看过几款主流产品后更确信,大部分成本其实花在了品牌溢价和外观设计上。三年前我第一次尝试自制蓝牙音箱&#xff…...

光伏电站运维必看:MPPT控制器参数怎么调?这5个坑你踩过几个?

光伏电站MPPT控制器实战调参指南:5个高频运维陷阱与破解方案 清晨六点,青海某光伏电站的监控系统发出警报——3号阵列发电量骤降23%。运维团队排查两小时才发现,问题竟出在MPPT控制器的电压扰动步长设置:默认参数在高原晨间快速变…...

FaceRecon-3D实战教程:构建人脸3D资产库的自动化Pipeline设计

FaceRecon-3D实战教程:构建人脸3D资产库的自动化Pipeline设计 1. 引言:从一张照片到3D资产 想象一下,你手头有成千上万张人物照片,可能是员工证件照、客户头像或者历史人物肖像。传统上,要把这些2D照片变成3D模型&am…...

TI盘古开发板+蓝牙模块:手把手教你实现无人机与消防小车的空地协同通信(附完整代码)

TI盘古开发板与蓝牙模块实战:空地协同通信系统开发全解析 1. 空地协同系统架构设计 在智能消防、农业巡检和工业监测等领域,无人机与地面设备的协同作业正成为技术热点。这套系统的核心在于建立稳定可靠的通信链路,实现实时数据交换与任务协…...

面试官: 主键索引特点解析(答案深度解析)持续更新

主键索引特点 —— 面试官想听的「底层逻辑」和「踩坑经验」⚠️ 注意:面试中只答“唯一、非空、聚簇索引”是及格线;真正拉开差距的,是你能否讲清 “为什么必须这样设计?”、“不这么干会怎样?”、“实际开发中哪些坑…...

2025届毕业生推荐的降AI率工具推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 为能切实有效地把内容被判定为AIGC的可能性降低,我们能够运用下面这一连串的策略…...