当前位置: 首页 > news >正文

LeetCodeHot100——155.最小栈

题目链接放在这里了:155. 最小栈 - 力扣(LeetCode)

这道题的思路就是要我们实现一个最小栈和它的基本几个功能,最小栈就是在一个栈的基础上,可以让我们知道这个栈任意时刻的最小值。我最初是想在一个栈的基础上加上一个属性用来存储最小值,如果你也这么想那么你就想的太简单了,如果栈里有5个元素,最小值肯定是确定了呗,那如果我们这时候pop了呢,那下一个最小值怎么确认?,难道还要存储倒数第二小的做备份吗,那倒数第二小的就不用更新了吗,依次往复我们是不是要记录从开始到结尾每个元素在栈顶时对应的最小值啊,那这样的话我们是不是就可以搞一个同步队列啊,根据栈里的对应关系,记录每个位置对应的最小值,这样是可以实现的,还有就是我们可以通过数组或者map的形式,我们的栈中存储的不再是简单的一个数字了,而是多个map或者多个大小为2的小数组,这样我们在push的时候,如果栈为空那就直接push(value,value),如果不为空那就peek()一下前一个的最小值,和这次要push的值做比较,取较小值作为当前值对应的最小值,这种思路下来我们在查看最小值的时候只需要peek然后查看最小值对应位置的元素就好了,这样栈中的每个元素都有其在栈顶时刻的最小值和value了;

下面是我的方法,我是使用了map,主要是想熟悉一下map的api,在我们不知道key值的时候想按序获取map的Key和Value使用map.entrySet().iterator().next().getValue()/getKey()来操作;

class MinStack { private Deque<Map<Integer,Integer>> stack; public MinStack() { stack = new LinkedList<>(); } public void push(int value) { Map<Integer,Integer> cur = new HashMap<>(); if(stack.isEmpty()){ cur.put(value,value); }else{ int t = stack.peek().entrySet().iterator().next().getValue(); cur.put(value,Math.min(value,t)); } stack.push(cur); } public void pop() { if(!stack.isEmpty()){ stack.pop(); } } public int top() { return stack.peek().entrySet().iterator().next().getKey(); } public int getMin() { return stack.peek().entrySet().iterator().next().getValue(); } } /** * Your MinStack object will be instantiated and called as such: * MinStack obj = new MinStack(); * obj.push(value); * obj.pop(); * int param_3 = obj.top(); * int param_4 = obj.getMin(); */
http://www.cnnetsun.cn/news/2905326.html

相关文章:

  • 微信聊天记录永久保存终极指南:掌握你的数字记忆主权
  • 5分钟构建专业级拼多多爬虫:Scrapy框架下的电商数据采集实战方案
  • AI 助手调试踩坑:5 轮瞎猜定位 4s budget 兜底路径(含 Hindsight 反思账本使用指南)
  • Keil5搭配STLink调试ARM工程,这几个隐藏设置能让你的效率翻倍(Reset and Run/速度优化)
  • VRoidStudio汉化插件终极指南:三步安装+个性化定制完整教程
  • 非遗正筋大师裴志刚走进哈萨克斯坦 患者不做手术感受中医绝技
  • 如何免费获取九大网盘直链下载链接:LinkSwift 完整使用指南
  • 2026海口市权威认证贵金属回收 TOP5+黄金回收白银回收铂金回收门店地址电话推荐
  • Pandas生产实战:性能瓶颈、链式赋值与内存优化避坑指南
  • 3步开启智能象棋对弈新时代:VinXiangQi深度体验指南
  • D3KeyHelper终极指南:构建专业级的暗黑3自动化技能系统
  • Hazel:AI 驱动政府采购变革,全栈工程师岗位等你来!
  • MC9S08QE128 DBG模块实战:非侵入式调试与硬件断点深度解析
  • 5分钟快速掌握Chrome网页批量文本替换:免费高效的终极解决方案
  • 跨平台漫画阅读神器:nhentai-cross完整使用指南,5大平台无缝切换体验
  • 户外徒步、越野跑必备:如何用手机App(如Gaia GPS)一键校正你所在城市的磁偏角?
  • 检索增强生成中的混合检索策略:稠密检索与稀疏检索的融合方案
  • NifSkope实战:Bethesda游戏3D模型编辑的5个核心痛点与解决方案
  • 15分钟快速上手:Switch大气层Atmosphere稳定版完全指南
  • (K12)static 局部变量什么时候会出问题?
  • 浏览器下载太慢?3个步骤让Motrix扩展帮你提速300%
  • 15分钟快速上手:Switch大气层Atmosphere稳定版完整安装指南
  • 跨境新店养号阶段环境精细化设置技巧
  • 如何快速解决Windows和Office激活难题:KMS_VL_ALL_AIO完整指南
  • MC68341 BDM调试模式:硬件原理、通信协议与实战应用
  • 医疗电子AFE设计实战:基于Kinetis K53的六合一测量平台解析
  • 如何永久保存微信聊天记录?WeChatMsg免费备份工具完全指南
  • 终极3DS游戏格式转换指南:5分钟将.3ds文件变为可安装CIA
  • R语言空间自相关分析保姆级教程:从shp文件到莫兰指数散点图(含完整代码与避坑指南)
  • 深入解析MC9RS08KB12内存架构与Flash编程实战