算法题(38):最小栈

审题:

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

思路:

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

思路一:维护min变量

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

思路二:辅助栈(minsta)

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

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

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

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

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

解题:

155. 最小栈 - 力扣(LeetCode)

相关推荐
smileNicky5 小时前
Redis系列之底层数据结构整数集IntSet
数据结构·数据库·redis
_extraordinary_8 小时前
list的模拟实现详解
数据结构·windows·list
ydm_ymz8 小时前
句子读单词
c语言·数据结构·算法·排序算法
yjhqukq9 小时前
递归40题!再见递归
c语言·数据结构·c++·算法·链表·双向链表
爱吃涮毛肚的肥肥(暂时吃不了版)11 小时前
Leetcode——链表:143.重排链表
数据结构·c++·后端·算法·leetcode·链表·职场和发展
wen__xvn13 小时前
每日一题洛谷P1428 小鱼比可爱c++
数据结构·c++·算法
小王努力学编程14 小时前
【C++篇】红黑树的实现
数据结构
酷酷的崽79814 小时前
【数据结构】—— 顺序表的实现与优化:空间管理与增容策略
c语言·数据结构
不玩return的马可乐15 小时前
LeeCode 1678. 设计 Goal 解析器
数据结构·c++·算法·leetcode·职场和发展