算法题(38):最小栈

审题:

这题需要我们实现一个可以在常数时间内检索到最小元素的栈

思路:

如果不限制时间复杂度,我们可以使用for循环遍历查找,但是这里限制了时间复杂度。

思路一:维护min变量

可以创建一个min变量,然后每次插入对象进去就和min进行比较,将较小的留给min。但是这存在一个大问题,一旦我们执行了pop函数,把min的数据删掉了,我们就无法获取当前最小的数了

思路二:辅助栈(minsta)

我们额外创建一个栈(minsta),它的目的是让栈顶保持为最小数据。

插入逻辑:一旦sta中插入了比minsta栈顶数据更小的数据,就往minsta中插入该数据。

删除逻辑:若sta删除的元素和minsta的栈顶元素值一样,那么minsta也需要删除栈顶元素

疑问:如果该数据和minsta栈顶数据一致还需要插入吗?

需要,因为如果最小数据存在两个以上,其中一个删除掉了,sta中仍然剩下该最小数据,若我们在minsta中只保存了一个该数据,那么删除之后minsta栈顶就不是最小数据了

解题:

155. 最小栈 - 力扣(LeetCode)

相关推荐
似水এ᭄往昔9 小时前
【C++】--AVL树的认识和实现
开发语言·数据结构·c++·算法·stl
TL滕10 小时前
从0开始学算法——第十六天(双指针算法)
数据结构·笔记·学习·算法
天赐学c语言10 小时前
12.14 - 搜索旋转排序数组 && 判断两个结构体是否相等
数据结构·c++·算法·leecode
1024肥宅11 小时前
JavaScript 性能与优化:数据结构和算法
前端·数据结构·算法
仰泳的熊猫11 小时前
1112 Stucked Keyboard
数据结构·c++·算法·pat考试
he___H11 小时前
滑动窗口一题
java·数据结构·算法·滑动窗口
AI科技星11 小时前
统一场论质量定义方程:数学验证与应用分析
开发语言·数据结构·经验分享·线性代数·算法
学编程就要猛12 小时前
数据结构初阶:Map和Set接口
数据结构
jianfeng_zhu12 小时前
不带头节点的链式存储实现链栈
数据结构·算法
历程里程碑12 小时前
C++ 7vector:动态数组的终极指南
java·c语言·开发语言·数据结构·c++·算法