• 155. 最小栈


    155. 最小栈

    设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。

    实现 MinStack 类:

    • MinStack() 初始化堆栈对象。
    • void push(int val) 将元素val推入堆栈。
    • void pop() 删除堆栈顶部的元素。
    • int top() 获取堆栈顶部的元素。
    • int getMin() 获取堆栈中的最小元素。

    输入:
    ["MinStack","push","push","push","getMin","pop","top","getMin"]
    [[],[-2],[0],[-3],[],[],[],[]]

    输出:
    [null,null,null,null,-3,null,0,-2]

    解释:
    MinStack minStack = new MinStack();
    minStack.push(-2);
    minStack.push(0);
    minStack.push(-3);
    minStack.getMin();   --> 返回 -3.
    minStack.pop();
    minStack.top();      --> 返回 0.
    minStack.getMin();   --> 返回 -2.

    题意:这个题题意就是得到栈中最小的数字,不管你是入栈还是出栈之后最终得到栈中的最小数字。

    思路:准备两个栈,一个栈是正常的栈,一个栈是保存栈中最小数字的的栈,我们也叫他最小栈,当两个栈刚开始为空时,我们就将元素同时入到这两个栈中,如果不为空,将元素入到第一个普通栈中,然后用这个元素与最小栈栈顶元素比较,如果大于最小栈栈顶元素就不入最小栈,如果小于最小栈栈顶元素就入最小栈。

    1. class MinStack {
    2. Stack<Integer> stack;
    3. Stack<Integer> minStack;
    4. public MinStack() {//初始化两个栈
    5. stack = new Stack<>();//普通栈
    6. minStack = new Stack<>();//最小栈
    7. }
    8. public void push(int val) {
    9. if(stack.empty()&&minStack.empty()){
    10. //两个栈都为空,同时push元素
    11. stack.push(val);
    12. minStack.push(val);
    13. }else {
    14. stack.push(val);
    15. if(val<=minStack.peek()){//比最小栈栈顶元素小就入
    16. minStack.push(val);
    17. }
    18. }
    19. }
    20. public void pop() {//出栈,如果出的是与最小栈栈顶元素相同,那么也同时出最小栈栈顶元素,保持最小栈栈顶依然是栈中最小的元素
    21. int x = stack.pop();
    22. if(x==minStack.peek()){
    23. minStack.pop();
    24. }
    25. }
    26. public int top() {//弹出普通栈栈顶元素
    27. return stack.peek();
    28. }
    29. public int getMin() {//最小栈栈顶元素就是最小值
    30. return minStack.peek();
    31. }
    32. }

  • 相关阅读:
    创建线程:Thread类和Runnable接口
    用DIV+CSS技术设计我的家乡网站(web前端网页制作课作业)南宁绿城之都
    软件测试 - 项目实战篇
    tcp三次握手的一些疑问
    最优化:建模、算法与理论(典型优化问题
    跨境电商去哪做好?东南亚六国电商情况一览
    希尔排序 java
    Volcano成Spark默认batch调度器
    saas系统隐私面单自定义教程
    如何设计分布式系统-分布式事务-TCC?
  • 原文地址:https://blog.csdn.net/m0_61210742/article/details/125556119