<span>【LeetCode】155. 最小栈</span>

题目描述

设计一个支持 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 操作总是在 非空栈 上调用。

题解思路

使用额外的栈(同步辅助栈)来完成。

由于栈有后进先出的特点。
假设元素a入栈时,栈里有元素 b、c、d,那么只要 a 在栈中,b、c、d 就一定会在栈中,因为在 a 被出栈前,b、c、d 不会被出栈。

我们使用同步辅助栈来依次存储新元素在入栈时当前整个栈的最小值。
当元素a入栈时,将当前整个栈的最小值min入栈到同步辅助栈中存储起来。

如果知道栈顶元素是a,那就可以直接知道此时原栈的最小值min了。

同步辅助栈与原栈的同步关系

入栈

  1. 当原栈为空,新元素a入栈时,将新元素a拷贝一份,并入栈到辅助栈当中。
  2. 当原栈非空,新元素k入栈时,取出辅助栈的栈顶元素min_top,与k比较,将min{k, min_top}入栈到辅助栈中去。

出栈

  1. 原栈有元素出栈,辅助栈同时将栈顶元素弹出。

在任意一个时刻,原栈内元素的最小值就存储在辅助栈的栈顶中。

代码

#define MAXSIZE 1600

typedef struct {
    // 只用一个(数组模拟的)栈来同时模拟原栈、同步辅助栈并存
    // 原栈:偶数,0,2,4......
    // 辅助栈:奇数,1,3,5......
    int top;
    int *data;
} 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 if(obj->top == -1){
        // 原栈
        obj->top++;
        obj->data[obj->top] = x;
        // 辅助栈
        obj->top++;
        obj->data[obj->top] = x;
    } else {
        // 当原栈非空,新元素k入栈时,取出辅助栈的栈顶元素min_top,与k比较,将`min{k, min_top}`入栈到辅助栈中去
        int tmp = obj->data[obj->top];
        // 原栈
        obj->top++;
        obj->data[obj->top] = x;
        // 辅助栈
        if(tmp < x){
            obj->top++;
            obj->data[obj->top] = tmp;
        } else {
            obj->top++;
            obj->data[obj->top] = x;
       }
    }
}

void minStackPop(MinStack* obj) {
    if(obj->top != -1){
        // 原栈
        obj->top--;
        // 辅助栈 
        obj->top--;
    }
}

int minStackTop(MinStack* obj) {
    if(obj->top == -1){
        return; // 返回空(void)
    }    
    return obj->data[obj->top-1]; // 必须减1,减1才是原栈的栈顶
}

int minStackGetMin(MinStack* obj) {
    // 在任意一个时刻,原栈内元素的最小值就存储在辅助栈的栈顶中
    return obj->data[obj->top];
}

void minStackFree(MinStack* obj) {
    free(obj->data);
    obj->data = NULL;
    free(obj);
    obj = NULL;
}

提交

优秀、精明的题解

  1. 【精选】使用辅助栈(同步和不同步)
  2. 详细通俗的思路分析,多解法
全部评论

相关推荐

机智的豹子有点心碎:UU我还在找工作还没找到,一直在搜简历怎么改,总结了这些: 1.SEO:简历根据每一个岗位定制化:使用这个岗位中所描述的工作的词,它要求什么技能就把自己的技能描述成什么样子,把SEO用在自己身上(把我的简历和个人特质,当成一个热门产品来做 “搜索引擎优化”),让HR能用最低的门槛看到我 2."顺序:把岗位要求的技能跟经历放在简历的最开头、最显眼的位置" 3.包装:简历是一个最终交付说明书,只要最终学习成长做得到就可以,在合适的范围内自我吹捧(我这个人怎么能够在HR的角度被迅速的看懂和看到,减轻HR的工作压力) 4.每点加小标题​:用6~10字概括该段内容,便于面试官快速抓取信息。 5.避免空泛描述​:拒绝“培养了组织能力”等泛泛而谈,替换为具体行动和成果。 6."使用“三段式结构”​​:每段经历按“为什么做-做了什么-结果如何”展开: ​a) 为什么做​:痛点或目标(例如“品牌声量不足”) ​b) 做​了什么:方法论(例如“趋势洞察+竞品对标+人群细分”) ​c) 结果如何​:量化成果或影响(例如“推动客户投放20万预算”)" 7.量化成果​:用数字体现工作成效(如“整理500+份资料”“撰写2万字报告”)。 这些有的是我想去的岗的,如果对你有用的话按需修改就好~加油,早日上岸!
点赞 评论 收藏
分享
zaakfung:26届不应该春招吗 为啥还实习
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务