题目:
设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。
实现 MinStack 类:
MinStack() 初始化堆栈对象。
void push(int val) 将元素val推入堆栈。
void pop() 删除堆栈顶部的元素。
int top() 获取堆栈顶部的元素。
int getMin() 获取堆栈中的最小元素。
示例 1:
输入:
["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.
提示:
<= val <= - 1
pop、top 和 getMin 操作总是在 非空栈 上调用
push, pop, top, and getMin最多被调用 次
解题思路:
定义栈的数据data,栈顶指针top,最小值min用于存储栈中的最小值,在入栈和出栈的时候将要入栈或出栈的数据与最小值min进行比较,若要入栈或进栈的数据小于这个最小值,则对其进行更新。
代码展示:
#define MAXSIZE 100000
typedef struct {
int *data;
int top;
int min;
} MinStack;
MinStack* minStackCreate() {
MinStack *obj;
obj = (MinStack * )malloc(sizeof(MinStack));
obj->data = (int * )malloc(MAXSIZE*sizeof(int));
obj->top = -1;
obj->min = INT_MAX;
return obj;
}
void minStackPush(MinStack* obj, int val) {
obj->min = obj->min<val?obj->min:val;
obj->data[++(obj->top)] = val;
}
void minStackPop(MinStack* obj) {
if(obj->top==-1)
return;
if(obj->data[obj->top]==obj->min)
{
--(obj->top);
if(obj->top!=-1)
{
obj->min = obj->data[obj->top];
for(int i = 0;i<obj->top;++i)
{
obj->min = obj->min < obj->data[i] ? obj->min : obj->data[i];
}
}
else
obj->min = INT_MAX;
}
else
--(obj->top);
}
int minStackTop(MinStack* obj) {
return obj->data[obj->top];
}
int minStackGetMin(MinStack* obj) {
return obj->min;
}
void minStackFree(MinStack* obj) {
free(obj->data);
free(obj);
}
/**
* Your MinStack struct will be instantiated and called as such:
* MinStack* obj = minStackCreate();
* minStackPush(obj, val);
* minStackPop(obj);
* int param_3 = minStackTop(obj);
* int param_4 = minStackGetMin(obj);
* minStackFree(obj);
*/