Stack_经典例题_最小栈

题目:

题目分析:

在满足栈的特点的同时,还需要设计一个接口,就是获取栈内的最小元素!

解题思路:

因为是栈,所以不好遍历的!所以这题的方式不能采用遍历的方式,如果采取更新数据的方式,则可以采取最小数字的方式进行更新:

当有元素入栈时,这个元素就会和一个初始化的数据进行比较,然后进行更新。

每入栈一个元素,都会更新最小值,直到入栈结束,但也是不行的,因为每当我们出一次栈,最小的数据就要更新一次!但是这次的更新需要遍历之前入栈的数据,但是栈是不能够使用遍历的!

所以我们采取使用两个栈的方式进行解答:

一个栈存储正常的数据,另一个栈存储当前最小的数据,这样就可以解决出栈问题。

当一个数据入栈后,立马更新当前栈内的最小元素,使用的是上面那个更新数据的方法,但是这个更新的数据会被丢进另一个栈中,然后当最小值保持不变时不入栈,每次最小值进行变动时则入栈。

之后另一个栈需要出栈时就将栈顶的元素和这个存储最小值元素的栈的栈顶元素进行比较,最小元素栈的栈顶元素更小,那就不出栈只有最小元素栈等于时那就双方都出栈!

不过会出现一个问题,那就是连续插入了相同的数字且都是最小值时,这里不能贸然的删去,所以需要进行一波判断!

代码分析:
完整代码:
相关推荐
汀、人工智能10 分钟前
[特殊字符] 第25课:合并两个有序链表
数据结构·算法·链表·数据库架构··合并两个有序链表
计算机安禾15 分钟前
【数据结构与算法】第30篇:哈希表(Hash Table)
数据结构·学习·算法·哈希算法·散列表·visual studio
AIminminHu15 分钟前
OpenGL渲染与几何内核那点事-项目实践理论补充(三-1-(3):番外篇-当你的CAD打开“怪兽级”STL时:从内存爆炸到零拷贝的极致优化
c++·零拷贝·mmap·内存拷贝
水饺编程16 分钟前
第4章,[标签 Win32] :SysMets3 程序讲解04,垂直滚屏重绘
c语言·c++·windows·visual studio
xiaoye-duck16 分钟前
《算法题讲解指南:动态规划算法--子序列问题(附总结)》--32.最长的斐波那契子序列的长度,33.最长等差数列,34.等差数列划分II-子序列
c++·算法·动态规划
BestOrNothing_201527 分钟前
C++零基础到工程实战(1.3):cpp注释与输出详解
c++·注释·命名空间·初学者教程·cout输出
CoderMeijun32 分钟前
C++构造与析构:对象的生与死
c++·面向对象·构造函数·析构函数·c++基础
REDcker32 分钟前
C++ 多线程内存模型与 memory_order 详解
java·c++·spring
AbandonForce33 分钟前
STL list
开发语言·c++
水饺编程34 分钟前
第4章,[标签 Win32] :SysMets3 程序讲解05,水平滚动
c语言·c++·windows·visual studio