Stack_经典例题_最小栈

题目:

题目分析:

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

解题思路:

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

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

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

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

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

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

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

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

代码分析:
完整代码:
相关推荐
samroom9 分钟前
【鸿蒙应用开发 Dev ECO Studio 5.0版本】从0到1!从无到有!最全!计算器------按钮动画、滑动退格、中缀表达式转后缀表达式、UI设计
数据结构·ui·华为·typescript·harmonyos·鸿蒙
xyx-3v10 分钟前
qt创建新工程
开发语言·c++·qt
算法鑫探23 分钟前
10个数下标排序:最大值、最小值与平均值(下)
c语言·数据结构·算法·排序算法·新人首发
样例过了就是过了28 分钟前
LeetCode热题100 爬楼梯
c++·算法·leetcode·动态规划
少司府36 分钟前
C++基础入门:类和对象(中)
c语言·开发语言·c++·类和对象·运算符重载·默认成员函数
王老师青少年编程43 分钟前
csp信奥赛c++之状压枚举
数据结构·c++·算法·csp·信奥赛·csp-s·状压枚举
Mr_Xuhhh1 小时前
深入理解二叉树:从数据结构到算法实战
数据结构·算法
ysa0510302 小时前
斐波那契上斐波那契【矩阵快速幂】
数据结构·c++·笔记·算法
早睡的叶子2 小时前
onnx模型数据结构分析,用于解析onnx模型
数据结构
@atweiwei2 小时前
Go语言面试篇数据结构底层原理精讲(下)
数据结构·面试·golang