难度简单759
设计一个支持
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.提示:
pop
、top
和getMin
操作总是在 非空栈 上调用。
栈的实现形式有两种,一个种是链表,另一种是数组。
面对这道题我用了笨笨的方法,即用数组来存储栈。
class MinStack {
public:
/** initialize your data structure here. */
// stack<int> x_stack;
vector<int> x_stack;
// stack<int> min_stack;
MinStack() {
// min_stack.push(INT_MAX);
}
void push(int x) {
x_stack.push_back(x);
// min_stack.push(min(min_stack.top(), x));
}
void pop() {
x_stack.pop_back();
// min_stack.pop();
}
int top() {
return x_stack[x_stack.size() - 1];
}
int getMin() {
if(x_stack.size() <= 0){
return INT_MIN;
}
int min = x_stack[0];
for(int i = 1; i <x_stack.size(); i++){
if (min > x_stack[i]){
min = x_stack[i];
}
}
return min;
}
};
/**
* 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();
*/
官方题解用到的是两个栈,一个辅助栈,一个最小栈。对辅助栈操作进栈出站和输入的数据一致,对最小栈的进栈是每次将栈顶的值和当前值进行比较取最小值,就是说最小栈中的元素是当前的最小值,且会重复进栈。这样能够使取得最小值时直接获得。
class MinStack {
public:
/** initialize your data structure here. */
stack<int> x_stack;
stack<int> min_stack;
MinStack() {
min_stack.push(INT_MAX);
}
void push(int x) {
x_stack.push(x);
min_stack.push(min(min_stack.top(), x));
}
void pop() {
x_stack.pop();
min_stack.pop();
}
int top() {
return x_stack.top();
}
int getMin() {
return min_stack.top();
}
};
/**
* 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();
*/
是的,事实就是,我的办法运行时间相比太长了。