注释处还是要小小注意一下的
class Solution {
public:
void push(int value) {
stack1.push(value);
// 这里相等也要入栈,避免栈空
if (stack2.empty() || value <= stack2.top()) {
stack2.push(value);
}
}
void pop() {
if (stack1.top() == stack2.top()) {
stack2.pop();
}
stack1.pop();
}
int top() {
return stack1.top();
}
int min() {
return stack2.top();
}
private:
std::stack<int> stack1;
std::stack<int> stack2;
};