• 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. }

  • 相关阅读:
    基于区块链与联邦学习技术的数据交易平台
    R可视化:plot函数基础操作,小白教程
    算法进阶——最小的K个数
    【react】父组件获取子组件实例对象/方法
    大数据精准营销数据分析处理(一)
    C语言链表详解
    深入浅出排序算法之归并排序
    sqlite3数据库Linux 系统移植和使用
    点餐小程序实战教程01需求分析
    python如何提取浏览器中保存的网站登录用户名密码
  • 原文地址:https://blog.csdn.net/m0_61210742/article/details/125556119