这里维护两个栈就行,一个用来当作正常的栈,另外一个用来当记录最小值的栈。
class Solution {
public:
//普通栈
stack<int> s1;
//记录最小值
stack<int> s2;
void push(int value) {
s1.push(value);
if(s2.empty() || s2.top() > value){
s2.push(value);
}else{
s2.push(s2.top());
}
}
void pop() {
s1.pop();
s2.pop();
}
int top() {
return s1.top();
}
int min() {
return s2.top();
}
};