zoukankan      html  css  js  c++  java
  • 堆栈-155-最小栈

    题目

    设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。
     
    push(x) —— 将元素 x 推入栈中。
    pop() —— 删除栈顶的元素。
    top() —— 获取栈顶元素。
    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.
     
     
    提示:
     
    pop、top 和 getMin 操作总是在 非空栈 上调用。
     
    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/min-stack
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
     
     
    思路分析:
    栈是属于一只有一个出口进行读取的数据结构,要在整个栈里进行遍历非常困难,所以我们自然想到用一个辅助栈来存储最小值;
    算法思路:
    用一个stack和一个minStack;minStack的栈顶用来存储当前stack栈中的最小元素;
    当push进一个元素时,stack中直接push进一个元素时,如果该元素小于等于minStack栈顶的元素时,即更新minStack,将其也push进minStack中。
    当pop时,注意pop的元素是否为minStack中的栈顶元素(即stack中最小元素),如果是,则minStack也要pop,更新最小元素;
    getMin直接弹出minStack中的栈顶元素即可
    代码如下:
    class MinStack {
        private Stack<Integer> stack;
        private Stack<Integer> minStack; //用来储存栈中的最小元素
    
        /** initialize your data structure here. */
        public MinStack() {
            stack=new Stack<Integer>();
            minStack=new Stack<Integer>();
        }
        
        public void push(int x) {  //辅助栈的栈顶元素一直是栈的最小元素
            stack.push(x);
            if(minStack.isEmpty() || x<=minStack.peek()){
                minStack.push(x);
            }
        }
        
        public void pop() { //注意pop时要看是否为栈额最小值,如果是,minStack栈也要更新
            int temp=stack.pop();
            if(temp==minStack.peek()){
                minStack.pop();
            }
        }
        
        public int top() {
            return stack.peek();
        }
        
        public int getMin() {  //直接将辅助栈的栈顶元素返回就行
            return minStack.peek();
        }
    }
  • 相关阅读:
    WM_PAINT消息详解,使用InvalidateRect或InvalidateRgn函数刻意产生WM_PAINT消息(WIN7里有变化,“调整视觉效果”,将“启用桌面组合”去掉)
    delphi 大文件的读写 使用 MapviewOffile
    Delphi的子类化控件消息, 消息子类化
    wParam与lParam的区别
    为什么使用DLL
    大数据分包算法
    JSON如何序列图片
    AngularJs学习
    设计模式解读
    js模块化编程总结
  • 原文地址:https://www.cnblogs.com/Yunus-ustb/p/12916432.html
Copyright © 2011-2022 走看看