题目
设计一个支持 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 操作总是在 非空栈 上调用。
题解
/** initialize your data structure here. */
#define MAXSIZE 800
typedef struct {
int *data;
int top;
} MinStack;
/** initialize your data structure here. */
MinStack* minStackCreate() {
MinStack *obj=(MinStack *)malloc(sizeof(MinStack));
obj->data=(int *)malloc(MAXSIZE*sizeof(int));
obj->top=-1;
return obj;
}
void minStackPush(MinStack* obj, int x) {
if(obj->top==MAXSIZE-1){
}else{
obj->top++;
obj->data[obj->top]=x;
}
}
void minStackPop(MinStack* obj) {
if(obj->top==-1){
}else{
obj->top--;
}
}
int minStackTop(MinStack* obj) {
if(obj->top==-1){
return;
}
return obj->data[obj->top];
}
int minStackGetMin(MinStack* obj) {
if(obj->top==-1) return;
if(obj->top==0){
return obj->data[obj->top];
}
int min=obj->data[0];
for(int i=0;i<=obj->top;i++){
if(obj->data[i]<min){
min=obj->data[i];
}
}
return min;
}
void minStackFree(MinStack* obj) {
free(obj->data);
obj->data=NULL;
free(obj);
obj=NULL;
}
/**
* Your MinStack struct will be instantiated and called as such:
* MinStack* obj = minStackCreate();
* minStackPush(obj, x);
* minStackPop(obj);
* int param_3 = minStackTop(obj);
* int param_4 = minStackGetMin(obj);
* minStackFree(obj);
*/