每日算法-最小栈

题目

设计一个支持 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.

提示:

  • poptopgetMin 操作总是在 非空栈 上调用。

解法

思路: 维护两个栈,一个是数据栈,一个最小值辅助栈。

在这里插入图片描述

class MinStack {
    
    
		
  	// 数据栈
    private Stack<Integer> dataStack;
		
  	// 最小值辅助栈
    private Stack<Integer> minStack;

    /** initialize your data structure here. */
    public MinStack() {
    
    
        dataStack = new Stack<>();
        minStack = new Stack<>();
    }
    
    public void push(int x) {
    
    
        dataStack.push(x);
        if(minStack.isEmpty() || x <= minStack.peek()){
    
    
            minStack.push(x);
        } else {
    
    
            minStack.push(minStack.peek());
        }
    }
    
    public void pop() {
    
    
        Integer pop = dataStack.pop();
        minStack.pop();
    }
    
    public int top() {
    
    
        return dataStack.peek();
    }
    
    public int getMin() {
    
    
        return minStack.peek();
    }
}

/**
 * Your MinStack object will be instantiated and called as such:
 * MinStack obj = new MinStack();
 * obj.push(x);
 * obj.pop();
 * int param_3 = obj.top();
 * int param_4 = obj.getMin();
 */

总结

本篇文章讲解了算法题目的思路和解法,代码和笔记由于纯手打,难免会有纰漏,如果发现错误的地方,请第一时间告诉我,这将是我进步的一个很重要的环节。以后会定期更新算法题目以及各种开发知识点,如果您觉得写得不错,不妨点个关注,谢谢。

猜你喜欢

转载自blog.csdn.net/weixin_45124488/article/details/114330838