最小栈--纯C解决

题目:实现一个O(1)时间复杂度搜索到最小值的栈

代码:

关键在于在入栈的同时进行最小值的比较和更新。
入栈时入两次栈(除了空栈情况),保持栈顶是最小值。
注意细节问题:

  1. 空栈情况的pop,一个元素情况的pop
  2. 空栈情况的push
#define SIZE 15000
typedef struct {
    int nums[SIZE];
    int top;
} MinStack;

/** initialize your data structure here. */

MinStack* minStackCreate() {
  MinStack* obj = malloc(sizeof(MinStack));
  obj->top = -1;
  return obj;
}
//重点就在于push和pop的处理
void minStackPush(MinStack* obj, int val) {
    //当栈空时只入一个,其他情况将栈顶与入栈元素进行比较,保持最小的元素在栈顶,入栈元素在栈顶的下一个。
    if(obj->top==-1)
    obj->nums[++(obj->top)] = val;
    else{
        int min = obj->nums[obj->top]>val?val:obj->nums[obj->top];
        obj->nums[++(obj->top)] = val;
        obj->nums[++(obj->top)] = min; 
    }
}

void minStackPop(MinStack* obj) {
    //若到了最后一个元素,则底下没有其他东西垫底需要特殊处理。
    //当栈为空则top不动。
    if(obj->top==-1){
        return;
    }
    //确保top指向最小值
    if(obj->top==0){
        obj->top=-1;
        return;
    }
    obj->top-=2;
}
//关键就在于能改变top指针的操作的设计,而下面两个不能影响top指针,所以很是简单。。
int minStackTop(MinStack* obj) {
    if(obj->top==0){
        return obj->nums[obj->top];
    }
    return obj->nums[obj->top-1];
}

int minStackGetMin(MinStack* obj) {
    return obj->nums[obj->top];
}

void minStackFree(MinStack* obj) {
    free(obj);
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值