import java.util.*;
import java.util.Stack;

public class Solution {

    Stack<Integer> stack1 = new Stack<Integer>(); 
    Stack<Integer> stack2 = new Stack<Integer>(); 

    public void push(int node) {
        stack1.push(node);
        //栈2为空直接将新结点入栈,栈2栈顶值比新结点大,新结点入栈
        if(stack2.isEmpty()||stack2.peek()>node){
            stack2.push(node);
        }else{
            stack2.push(stack2.peek());
        }
    }
    
    public void pop() {
        stack1.pop();
        stack2.pop();
    }
    
    public int top() {
        return stack1.peek();
    }
    
    public int min() {
        return stack2.peek();
    }
}

方法:双栈思想

栈1用于存储入栈的所有结点,栈2存储目前每个阶段最小的结点值(可能有重复),入栈时正常入栈1,到栈2就得判断栈是否为空以及栈顶元素(上一个最小值)与新结点谁值更大,当栈2为空或者栈顶元素比当前栈顶元素还小时,新结点入栈即更新最小元素值,否则原来的栈顶再入栈(多存一份)表示当前最小值没变。

其他方法如pop时两个栈都弹出,top时获取的是栈1的栈顶元素且不出栈,所以用peek()函数。min函数就是将栈2的栈顶元素返回。

记:Java 栈Stack的peek()方法,只返回栈顶元素而不弹出栈。