leetcode-155. 最小栈
-
首先关键是动态维护最小值,就是弹出元素为最小值的时候,如何知道次最小值
-
可以使用一个辅助栈mStack,mStack只用于存储push路径上的所有曾经的最小值,mStack的栈顶一直都是stack中的最小值
-
-
比较Integer需要用equal(),小心小于-128-127这个范围里的数字
class MinStack { /* 关键是维护最小值,并且弹出栈顶元素最小值的时候,怎么知道次最小值。 */ private Stack<Integer> stack; //原栈 private Stack<Integer> mStack; //最小栈,保存着那些曾经最小的值 public MinStack() { this.stack = new Stack<>(); this.mStack = new Stack<>(); } public void push(int val) { stack.push(val); if(mStack.isEmpty() || val <= mStack.peek()){//第一次添加val,把最小值存贮到mStack的栈顶,每次push数的时候小于mStack的栈顶则同时push到mStack mStack.push(val); } } public void pop() { if(stack.pop().equals(mStack.peek())){ mStack.pop(); } } public int top() { return stack.peek(); //返回原栈顶元素 } public int getMin() { return mStack.peek(); //返回最小栈顶 } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律