/**
*题目描述:
*定义栈的数据结构,请在该类型中实现一个能够得到栈最小元素的min函数。
*/
import java.util.Stack;
public class Solution {
Stack<Integer> data = new Stack<Integer>();
Stack<Integer> min = new Stack<Integer>();
public void push(int node) {
data.push(node);
if(min.isEmpty())
min.push(node);
else{
if(node<=min.peek())
min.push(node);
}
}
public void pop() {
if(data.peek()==min.peek())
min.pop();
data.pop();
}
public int top() {
return data.peek();
}
public int min() {
return min.peek();
}
public static void main(String[] args) {
Solution s=new Solution();
s.push(2);
s.push(1);
s.push(3);
s.push(4);
System.out.println(s.min());
System.out.println(s.top());
}
}