• 最小栈


    题目描述:

    设计一个支持 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.
    
    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/min-stack
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    解题思路:

    要做出这道题目,首先要理解「栈」结构先进后出的性质。

    要求的 push(x) 、pop() 、top() 其实用正常的栈就可实现,

    而要求 getMin() 在常数时间检索栈中的最小元素,则需要我们改造栈结构。

    所以,我们可以使用一个「辅助栈」,与数据栈同步插入与删除,用于存储与每个元素对应的最小值。

    • 当一个元素要入栈时,我们取当前辅助栈的栈顶存储的最小值,与当前元素比较得出最小值,将这个最小值插入辅助栈中;

    • 当一个元素要出栈时,我们把辅助栈的栈顶元素也一并弹出;

    • 在任意一个时刻,栈内元素的最小值就存储在辅助栈的栈顶元素中。

    //go
    type MinStack struct {
        data []int //数据栈,存数据
        help []int //辅助栈,存最小值
    }
    
    
    /** initialize your data structure here. */
    func Constructor() MinStack {
        return MinStack{
            data: []int{},
            help: []int{math.MaxInt64},
        }
    }
    
    
    func (this *MinStack) Push(x int)  {
        // 数据栈
        this.data = append(this.data, x)
        // 辅助栈
        this.help = append(this.help, min(x, this.help[len(this.help)-1]))
        
    }
    
    
    func (this *MinStack) Pop()  {
        if len(this.data) != 0 {
            this.data = this.data[:len(this.data)-1]
            this.help = this.help[:len(this.help)-1]
        }
    }
    
    
    func (this *MinStack) Top() int {
        return this.data[len(this.data)-1]
    }
    
    
    func (this *MinStack) GetMin() int {
        return this.help[len(this.help)-1]
    }
    
    func min(x, y int) int {
        if x < y {
            return x
        }
        return y
    }
    

      地址:https://mp.weixin.qq.com/s/r-Dv5hcR5VAhskupJP4pYA

  • 相关阅读:
    判断一个数组是不是一维数组
    XML5个转义符:<,>,&,”,©;的转义字符分别如下: &lt; &gt;&amp; &quot; &apos;
    linux crontab & 每隔10秒执行一次
    微信企业号-根据code获取成员信息(过期code)
    Namespace declaration statement has to be the very first statement in the script-去除bom头
    去掉一个字符前面的全部0
    检查一个数字是否为个位数
    nginx配置location总结及rewrite规则写法
    QT 4.7支持中文(QT4.7)(中文)(makeqpf)
    【转】vlc android 代码编译
  • 原文地址:https://www.cnblogs.com/smallleiit/p/13710223.html
Copyright © 2020-2023  润新知