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

栈结构实战:从「有效括号」到「最小栈」,吃透栈的核心用法

目录一、入门必刷LeetCode 20. 有效的括号题目描述解题思路代码实现Java复杂度分析二、进阶挑战LeetCode 155. 最小栈题目描述解题思路代码实现Java复杂度分析三、两道题的核心思想总结栈作为一种 “后进先出LIFO” 的数据结构看似简单却是算法题里的常客。今天我们就通过两道经典题 ——「有效括号」和「最小栈」把栈的核心思想和应用场景讲透看完你就能直接上手写代码。一、入门必刷LeetCode 20. 有效的括号这是一道几乎所有栈入门都会遇到的题目也是面试中的高频题非常适合理解栈的核心特性。题目描述给定一个只包括(){}[]的字符串s判断字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。每个右括号都有一个对应的相同类型的左括号。解题思路这道题的核心逻辑完美契合了栈 “后进先出” 的特性遇到左括号直接压入栈中等待后续匹配。遇到右括号需要和最近的一个未匹配的左括号配对。而栈顶元素正好就是最近的左括号。匹配失败的情况栈为空却遇到了右括号没有左括号可以匹配。栈顶的左括号类型和当前右括号不匹配。遍历结束后栈必须为空所有左括号都找到了对应的右括号。为了快速判断括号类型我们可以用一个哈希表来存储 “右括号 → 左括号” 的映射。代码实现Javajava运行public boolean isValid(String s) { // 定义右括号到左括号的映射方便匹配 MapCharacter, Character map new HashMap(); map.put(), (); map.put(}, {); map.put(], [); DequeCharacter stack new LinkedList(); for (char c : s.toCharArray()) { // 如果是右括号 if (map.containsKey(c)) { // 栈为空或栈顶元素不匹配直接返回false if (stack.isEmpty() || stack.peek() ! map.get(c)) { return false; } // 匹配成功弹出栈顶元素 stack.pop(); } else { // 如果是左括号直接入栈 stack.push(c); } } // 遍历结束栈必须为空 return stack.isEmpty(); }复杂度分析时间复杂度O (n)其中 n 是字符串的长度我们只需遍历一次字符串。空间复杂度O (n)最坏情况下所有字符都是左括号需要将所有字符压入栈中。二、进阶挑战LeetCode 155. 最小栈这道题是栈的经典扩展它要求我们在实现常规栈功能的同时支持在常数时间内获取栈中的最小元素。题目描述设计一个支持pushpoptop操作并能在常数时间内检索到最小元素的栈。实现MinStack类MinStack()初始化堆栈对象。void push(int val)将元素 val 推入堆栈。void pop()删除堆栈顶部的元素。int top()获取堆栈顶部的元素。int getMin()获取堆栈中的最小元素。解题思路这道题的难点在于如何在O(1)时间内获取最小值。如果每次都遍历栈来查找最小值时间复杂度会退化为 O (n)无法满足题目要求。最经典的解法是使用双栈主栈dataStack用来正常存储所有元素实现push、pop、top等常规操作。辅助栈minStack用来存储 “当前栈中的最小值”。每次主栈压入一个新元素时辅助栈也压入当前的最小值每次主栈弹出元素时辅助栈也同步弹出。这样getMin()方法只需要直接返回辅助栈的栈顶元素即可时间复杂度为 O (1)。代码实现Javajava运行class MinStack { // 主栈存储所有元素 private DequeInteger dataStack; // 辅助栈存储当前的最小值 private DequeInteger minStack; public MinStack() { dataStack new LinkedList(); minStack new LinkedList(); } public void push(int val) { dataStack.push(val); // 辅助栈为空或新元素小于等于当前最小值压入新元素 if (minStack.isEmpty() || val minStack.peek()) { minStack.push(val); } else { // 否则重复压入当前最小值保持两栈同步 minStack.push(minStack.peek()); } } public void pop() { // 两栈同步弹出 dataStack.pop(); minStack.pop(); } public int top() { return dataStack.peek(); } public int getMin() { // 直接返回辅助栈栈顶元素 return minStack.peek(); } }复杂度分析时间复杂度所有操作push、pop、top、getMin均为 O (1)。空间复杂度O (n)我们使用了两个栈在最坏情况下需要存储 2n 个元素。三、两道题的核心思想总结这两道题从不同角度展现了栈的应用有效括号利用栈 “后进先出” 的特性处理需要按顺序匹配的场景比如括号匹配、HTML 标签闭合等。最小栈利用 “双栈同步” 的思想在保留常规栈功能的同时扩展出了高效获取最小值的能力这是一种非常经典的空间换时间的优化思路。

相关文章:

栈结构实战:从「有效括号」到「最小栈」,吃透栈的核心用法

目录 一、入门必刷:LeetCode 20. 有效的括号 题目描述 解题思路 代码实现(Java) 复杂度分析 二、进阶挑战:LeetCode 155. 最小栈 题目描述 解题思路 代码实现(Java) 复杂度分析 三、两道题的核心…...

SSHFS-Win终极指南:在Windows上快速挂载远程Linux文件系统的完整教程

SSHFS-Win终极指南:在Windows上快速挂载远程Linux文件系统的完整教程 【免费下载链接】sshfs-win SSHFS For Windows 项目地址: https://gitcode.com/gh_mirrors/ss/sshfs-win SSHFS-Win是一款革命性的开源工具,让Windows用户能够通过SSH协议直接…...

计算机毕业设计:Python股票智能诊断与趋势预测系统 Flask框架 深度学习 机器学习 AI 大模型(建议收藏)✅

1、项目介绍 技术栈 Python语言、Flask框架、Tensorflow深度学习、LSTM神经网络算法股票价格预测、scikit-learn机器学习、东方财富数据源、Echarts可视化、HTML 功能模块 涨停板热点分析首页功能模块介绍大盘指数行情分析个股量化分析大盘资金流向分析大盘市场基本面估值分…...

终极指南:从实模式到保护模式的内存管理转换

终极指南:从实模式到保护模式的内存管理转换 【免费下载链接】os-tutorial How to create an OS from scratch 项目地址: https://gitcode.com/gh_mirrors/os/os-tutorial 在操作系统开发中,内存管理是核心挑战之一。本教程将带你了解如何从16位实…...

AI模型精度格式解析:从FP32到INT8的优化实践

1. 精度格式的厨房哲学 在AI模型的训练和推理过程中,数值精度格式就像厨师手中的刀具——不同的菜品需要不同的刀工。FP32好比主厨刀,能处理所有精细操作;FP16像切片刀,轻便但需要技巧;INT8则是剁骨刀,粗暴…...

LADB DNS发现机制解析:自动检测ADB端口的智能算法

LADB DNS发现机制解析:自动检测ADB端口的智能算法 【免费下载链接】LADB A local ADB shell for Android! 项目地址: https://gitcode.com/gh_mirrors/la/LADB LADB(Local ADB shell for Android)是一款专为Android设备设计的本地ADB …...

探索ECDF在运动数据分析中的应用

在数据分析领域,经验累积分布函数(ECDF)是一种非常有用的工具,可以帮助我们理解数据的分布情况。本文将结合运动数据的实例,展示如何使用ECDF来分析运动员的表现,并进一步探讨如何将时间格式的数据转换为可用于ECDF计算的数值。 背景介绍 假设我们有一组运动员的20分钟…...

3行代码实现滚动触发动画:lottie-web + Intersection Observer终极指南

3行代码实现滚动触发动画:lottie-web Intersection Observer终极指南 【免费下载链接】lottie-web Render After Effects animations natively on Web, Android and iOS, and React Native. http://airbnb.io/lottie/ 项目地址: https://gitcode.com/gh_mirrors/…...

抖音去水印下载工具:让内容创作素材获取更高效

抖音去水印下载工具:让内容创作素材获取更高效 【免费下载链接】TikTokDownload 抖音去水印批量下载用户主页作品、喜欢、收藏、图文、音频 项目地址: https://gitcode.com/gh_mirrors/ti/TikTokDownload 你是否曾在抖音上看到一段精彩的视频,想要…...

使用 Python 在 PPT 中创建文本框并设置格式的详细方法

刘姐是个行政主管,每周要给全公司做周报PPT。内容倒是不难,数据都是现成的,翻来覆去就那几项核心指标。最要命的是排版——每页都要重新拖文本框、调字号、改字体、设置行距,一干就是大半个下午。她总跟我抱怨,说最可恨…...

CodeWeaver:用Go实现的代码库文档化工具,助力AI编程与团队协作

1. 项目概述:CodeWeaver,一个为AI时代而生的代码库文档化工具 如果你和我一样,经常需要把整个项目的代码库打包成一个文件,扔给大语言模型(比如ChatGPT、Claude或者Cursor的AI)去分析,或者只是…...

保姆级教程:用GEMMA 0.98.5做GWAS分析,从数据整理到遗传力解读,一次搞定

GEMMA 0.98.5实战指南:从GWAS分析到遗传力深度解析 在基因组学研究中,全基因组关联分析(GWAS)已成为揭示复杂性状遗传基础的重要工具。而GEMMA作为一款高效的混合线性模型(MLM)实现软件,凭借其优秀的计算性能和稳定的算法表现,在生…...

florr.io新手必看:从Ant Egg到Mythic,一份超详细的生物掉落率速查表(附实战心得)

florr.io生物掉落率全解析:从Ant Egg到Mythic的实战效率手册 刚入坑florr.io时,你是否也经历过盯着满屏生物却不知道刷哪个的迷茫?当背包里塞满Common级材料却卡在装备升级瓶颈时,是否想过"如果早知道这个掉落率就好了"…...

告别Electron!用Qt QWebEngine + QWebChannel 打造高性能桌面混合应用(附完整Demo)

突破Electron性能瓶颈:Qt QWebEngine与QWebChannel混合开发实战指南 在桌面应用开发领域,Electron框架凭借其跨平台特性和Web技术栈的易用性长期占据主导地位。然而随着应用复杂度提升,Electron的内存占用高、启动缓慢和包体积庞大等问题逐渐…...

雀魂AI助手Akagi:3分钟学会用AI提升你的麻将水平

雀魂AI助手Akagi:3分钟学会用AI提升你的麻将水平 【免费下载链接】Akagi 支持雀魂、天鳳、麻雀一番街、天月麻將,能夠使用自定義的AI模型實時分析對局並給出建議,內建Mortal AI作為示例。 Supports Majsoul, Tenhou, Riichi City, Amatsuki, …...

2025届最火的降AI率平台推荐榜单

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 在撰写毕业论文的进程当中,人工智能工具能够显著地提高文献整理效率,…...

别再只用ECharts了!试试用Three.js为你的数据大屏打造酷炫3D地图底座(Vue3+TS版)

突破平面边界:用Three.js与Vue3构建下一代3D地理可视化方案 当数据大屏遇上3D地图,传统的二维图表突然显得单薄无力。去年某全球电商平台的数据显示,采用3D可视化的运营大屏用户停留时长提升47%,这背后是立体空间带来的信息纵深与…...

如何快速在云端启动VSCode:colabcode 5分钟入门指南

如何快速在云端启动VSCode:colabcode 5分钟入门指南 【免费下载链接】colabcode Run VSCode (codeserver) on Google Colab or Kaggle Notebooks 项目地址: https://gitcode.com/gh_mirrors/co/colabcode colabcode是一个强大的工具,能够帮助用户…...

2025届最火的六大降重复率神器实测分析

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek DeepSeek身为智能写作辅助工具,于学术论文撰写里呈现出显著效能,用户…...

VS Code Copilot Next 配置黄金标准(2024企业级落地白皮书)

更多请点击: https://intelliparadigm.com 第一章:VS Code Copilot Next 自动化工作流配置对比评测报告概述 VS Code Copilot Next 是微软与 GitHub 联合推出的下一代智能编程助手,其核心升级聚焦于本地化推理、上下文感知增强及可扩展工作流…...

【限时技术解禁】Docker AI Toolkit 2026企业版密钥注入机制首度披露:RBAC+模型水印+审计日志三级合规配置(含OpenSSF Scorecard 9.8分验证路径)

更多请点击: https://intelliparadigm.com 第一章:Docker AI Toolkit 2026企业版密钥注入机制全景概览 Docker AI Toolkit 2026企业版引入了零信任密钥注入框架(Zero-Trust Key Injection Framework, ZKIF),通过容器生…...

yt-dlp-gui开发者指南:如何扩展新的视频平台支持

yt-dlp-gui开发者指南:如何扩展新的视频平台支持 【免费下载链接】yt-dlp-gui Windows GUI for yt-dlp 项目地址: https://gitcode.com/gh_mirrors/yt/yt-dlp-gui yt-dlp-gui是一款强大的Windows视频下载工具,它为命令行工具yt-dlp提供了直观的图…...

告别“画饼”:PLUTO如何用对比学习让自动驾驶规划更像老司机?

PLUTO框架:用对比学习重塑自动驾驶决策逻辑 1. 自动驾驶规划的技术演进困境 当特斯拉车辆在十字路口突然急刹,或Waymo无人车在无保护左转时犹豫不决,这些现象揭示了当前自动驾驶规划系统的根本性挑战——如何让机器理解驾驶场景中的因果逻辑。…...

从‘False’到‘True’:一次搞定Windows下PyTorch与CUDA环境联调(以RTX 3060 + CUDA 11.6实战为例)

从‘False’到‘True’:一次搞定Windows下PyTorch与CUDA环境联调(以RTX 3060 CUDA 11.6实战为例) 去年夏天,当我第一次在个人电脑上尝试运行深度学习模型时,torch.cuda.is_available()那个刺眼的False让我意识到——…...

明日方舟游戏资源库:如何一站式获取超过12000个高清游戏素材

明日方舟游戏资源库:如何一站式获取超过12000个高清游戏素材 【免费下载链接】ArknightsGameResource 明日方舟客户端素材 项目地址: https://gitcode.com/gh_mirrors/ar/ArknightsGameResource 你是否曾为寻找高质量的游戏开发素材而烦恼?是否在…...

从Rancher Server到Node Agent:一张图看懂Rancher 2.8架构,搞懂它如何“遥控”你的K8s

Rancher 2.8架构深度解析:从UI点击到Pod创建的完整链路追踪 当你点击Rancher UI上的"创建工作负载"按钮时,这个看似简单的操作背后究竟发生了什么?本文将带你穿透表象,沿着请求链路逐层拆解Rancher 2.8的完整架构体系。…...

[特殊字符] 终极漫画阅读体验:Venera 开源阅读器完整指南!

🌟 终极漫画阅读体验:Venera 开源阅读器完整指南! Venera 是一款免费开源的漫画阅读神器,支持本地与网络漫画无缝阅读,让你随时随地享受沉浸式漫画时光!无论是珍藏的本地漫画文件,还是热门的网…...

AI遗嘱规划师:模型生命终结协议

从软件到遗产的测试思维跃迁在数字化浪潮的深处,一个全新的职业疆域正在被开垦。当人工智能模型从实验室走向社会,融入生活的毛细血管,它们不仅输出智能,也悄然累积着价值、责任与潜在的“数字人格”。作为一名软件测试从业者&…...

令牌管理革命:Tiktokenizer如何实现AI成本精准控制

令牌管理革命:Tiktokenizer如何实现AI成本精准控制 【免费下载链接】tiktokenizer Online playground for OpenAPI tokenizers 项目地址: https://gitcode.com/gh_mirrors/ti/tiktokenizer 在AI应用开发实践中,技术团队面临着一个看似简单却影响深…...

如何快速入门数据工程:GitHub精选项目data-engineer-handbook完整指南

如何快速入门数据工程:GitHub精选项目data-engineer-handbook完整指南 【免费下载链接】data-engineer-handbook This is a repo with links to everything youd ever want to learn about data engineering 项目地址: https://gitcode.com/GitHub_Trending/da/da…...