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

栈的应用场景(三)

最小栈

    • 1.题目
    • 2.画图分析
    • 3.代码实现

1.题目

在这里插入图片描述

2.画图分析

在这里插入图片描述
在这里插入图片描述

3.代码实现

package Stack;import java.util.Stack;
public class MinStack {private Stack <Integer> stack;private Stack <Integer> MinStack;public MinStack() {stack = new Stack<>();MinStack = new Stack<>();}public void push(int val) {//普通栈只要是元素都得放//最小栈 如果为空,放元素.如果不为空且要放的元素比栈顶元素小,也要放stack.push(val);if(MinStack.empty()){MinStack.push(val);}else{int peek = MinStack.peek();if(val <= peek){MinStack.push(val);}}}public void pop() {int val = stack.pop();//如果最小栈不为空if(!MinStack.empty()){if(val == MinStack.peek()){MinStack.pop();}}}//获取普通栈的栈顶public int top() {return stack.peek();}public int getMin() {if(!MinStack.empty()){return MinStack.peek();}return -1;}
}
http://www.lryc.cn/news/181387.html

相关文章:

  • leetCode 45.跳跃游戏 II 贪心算法
  • 【MATLAB-基于直方图优化的图像去雾技术】
  • 读书笔记|《数据压缩入门》—— 柯尔特·麦克安利斯 亚历克斯·海奇
  • Pandas进阶修炼120题-第五期(一些补充,101-120题)
  • NPDP产品经理知识(产品创新管理)
  • Flutter+SpringBoot实现ChatGPT流实输出
  • 淘宝天猫粉丝福利购店铺优惠券去哪里找到领取网站?
  • 【考研复习】union有关的输出问题
  • Android学习之路(16) Android 数据库Litepal
  • Redis持久化(RDB/AOF)
  • 小谈设计模式(15)—观察者模式
  • 简单工厂模式 创建型模式(非GoF经典设计模式)
  • PE文件之导入表
  • 二、码制及其转换
  • 在pycharm中出现下载软件包失败的解决方法
  • 10.0 探索API调试事件原理
  • 文心一言 VS 讯飞星火 VS chatgpt (104)-- 算法导论10.1 2题
  • 检测防火墙是否开启、判断程序是否加入防火墙白名单(附源码)
  • vtk 动画入门 1 代码
  • 【VR】【unity】如何在VR中实现远程投屏功能?
  • OpenGl材质
  • 背包问题
  • JavaSE | 初始Java(十一) | 抽象类和抽象接口
  • 产品经理如何科学的进行需求调研?
  • AI智能问答系统源码/AI绘画商业系统/支持GPT联网提问/支持Midjourney绘画
  • 玩具玩偶配送经营商城小程序的作用是什么?
  • latex表格内容换行
  • 2023 牛客国庆day4 【10.2训练补题】
  • android的USB开发时 mUsbManager.getDeviceList()获取都为空
  • SpringCloud Alibaba - Seata 部署 TC 服务,并集成微服务