0

0

C++怎么实现最小栈_C++O(1)获取栈最小值【数据】

尼克

尼克

发布时间:2026-02-23 11:37:02

|

287人浏览过

|

来源于php中文网

原创

单用一个栈无法o(1)获取最小值,因其仅支持栈顶操作,而最小值可能位于任意位置;需用辅助栈同步记录“截至当前的最小值”,push时x≤minstack.top()才入栈,pop时主栈弹出值等于minstack栈顶则同步弹出。

c++怎么实现最小栈_c++o(1)获取栈最小值【数据】

为什么单用一个没法 O(1) 拿到最小值

因为栈只允许在栈顶增删,而最小值可能藏在任意一层。如果每次 getMin() 都遍历一遍,就是 O(n),不满足题干要求。

核心思路是:用空间换时间,额外维护一个“同步栈”,它和主栈一起压入/弹出,但只存“到当前位置为止的最小值”。

  • 主栈进 5,当前全局最小是 5 → 辅助栈也进 5
  • 主栈再进 3,比辅助栈顶 5 小 → 辅助栈进 3
  • 主栈再进 4,不比辅助栈顶 3 小 → 辅助栈不动(或进 3,两种实现都行)
  • getMin() 直接返回辅助栈顶,O(1)

push() 时辅助栈怎么更新才不出错

关键在判断逻辑:辅助栈只在新元素 ≤ 当前最小值时才压入。用 而不是 <code>,否则重复最小值会被漏掉,导致 <code>pop()getMin() 返回错误值。

比如连续压入 3, 1, 1, 4,如果辅助栈只在 时进栈,第二个 <code>1 就不会进,等第一个 1 弹出后,辅助栈空了,但实际最小值还是 1

立即学习C++免费学习笔记(深入)”;

实操建议:

讯飞听见会议
讯飞听见会议

科大讯飞推出的AI智能会议系统

下载
  • 初始化两个空 std::stack<int></int>:主栈 mainStack 和辅助栈 minStack
  • push(x) 时:先压 mainStack,再判断 minStack.empty() || x ,成立则压 <code>minStack
  • 别忘了处理空栈边界——getMin() 前必须检查 minStack.empty(),否则 .top() 未定义行为

pop() 时辅助栈要不要跟着弹

要,而且必须严格同步:只要 mainStack 弹出的值等于 minStack.top()minStack 就必须跟着弹一个。

不能只看“是不是当前最小”,而要看“它是不是当时被记下来的那个最小”。否则会残留过期最小值。

常见错误现象:push(2), push(1), push(1), pop(), getMin() 返回 1 是对的;但如果 pop() 时没检查相等就跳过辅助栈,第二次 getMin() 可能仍返回 1(其实是错的,应仍为 1?等等——这里恰恰说明:重复值必须都记,也必须都弹)

所以正确逻辑是:

  • pop() 先取 mainStack.top(),然后 mainStack.pop()
  • 再比较这个值是否等于 minStack.top(),相等则 minStack.pop()
  • 不相等就不管辅助栈

C++ 实现里最容易崩的三个点

不是算法难,是 C++ 栈操作细节容易踩雷:

  • std::stack::top() 对空栈调用是未定义行为,不是抛异常——程序可能当场崩溃或静默错乱,务必每次调用前用 .empty() 检查
  • 不要用 std::stack 的底层容器(如 std::vector)直接访问,它没暴露 operator[] 或迭代器;想调试时看内容,得临时转成 vector 或用 while (!s.empty()) { auto t = s.top(); s.pop(); ... }
  • 如果题目要求支持 getMin() 在空栈时返回特殊值(如 INT_MAX),别直接 return,先判空;否则线上环境可能触发 sanitizer 报告

复杂点不在结构,而在每一步的边界守卫。少一个 empty() 检查,就可能让整个类在特定输入下失效。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

103

2023.09.25

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

830

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

580

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

274

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

210

2025.08.29

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

422

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

595

2023.08.10

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

467

2023.08.14

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1030

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1万人学习

进程与SOCKET
进程与SOCKET

共6课时 | 0.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号