【LeetCode】剑指 Offer(12)
创始人
2024-05-27 12:16:32
0

目录

题目:剑指 Offer 30. 包含min函数的栈 - 力扣(Leetcode)

题目的接口:

解题思路:

代码:

过啦!!!

写在最后:


题目:剑指 Offer 30. 包含min函数的栈 - 力扣(Leetcode)

 

题目的接口:

class MinStack {
public:/** initialize your data structure here. */MinStack() {}void push(int x) {}void pop() {}int top() {}int 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->min();*/

解题思路:

这道题的思路很巧妙,

我的思路是,通过建立两个栈来实现这个能够做到O(1)取最小值的栈。

如果一个栈正常压栈出栈,

一个栈用来放最小值,每次有最小值就放进去,

 然后这是代码:

class MinStack {
public:MinStack() {}void push(int val) {_st.push(val);//如果出现<=之前的数据if(_minST.empty() || _minST.top()>=val){_minST.push(val);}}void pop() {if(_st.top()==_minST.top())_minST.pop();        _st.pop();}int top() {return _st.top();}int getMin() {return _minST.top();}
private:stack _st;stack _minST;
};/*** Your MinStack object will be instantiated and called as such:* MinStack* obj = new MinStack();* obj->push(val);* obj->pop();* int param_3 = obj->top();* int param_4 = obj->getMin();*/

但是我当时做题的时候一下子脑子没转过来,

没用上面那种思路,

就想着简化一下出栈的操作,就想改进一下这个思路:(其实没必要,两种思路差别不大)

就每次入栈都入一遍,

出栈一起出就行,就不用判断是不是最小值再出。 

代码如下:

代码:

class MinStack {
public:/** initialize your data structure here. *///建两个栈stack st_push;stack st_min;MinStack() {}void push(int x) {//正常入栈st_push.push(x);//如果是空就直接入栈if(st_min.empty()){st_min.push(x);}//如果遇到更小的值就改变入栈的值else if(st_push.top() < st_min.top()){st_min.push(st_push.top());}else//如果没遇到更小的值就再入一次{st_min.push(st_min.top());}}void pop() {//直接同时出栈st_push.pop();st_min.pop();}int top() {return st_push.top();}int min() {return st_min.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->min();*/

过啦!!!

写在最后:

以上就是本篇文章的内容了,感谢你的阅读。

如果喜欢本文的话,欢迎点赞和评论,写下你的见解。

如果想和我一起学习编程,不妨点个关注,我们一起学习,一同成长。

之后我还会输出更多高质量内容,欢迎收看。

相关内容

热门资讯

谁可以给我说,古代诗词的韵分哪... 谁可以给我说,古代诗词的韵分哪几种?非常感谢 古代诗词用韵,不同时期有差别。使用时间最长、影响最广、...
郑煤机(00564)中文名称变... 郑煤机(00564)发布公告,于2025年7月7日,公司完成了公司名称的工商变更登记手续,并取得了郑...
国足0比3不意外 转自:京报网_北京日报官方网站 【#国足0比3不意外#】...
有关中国古代天文学的书 有关中国古代天文学的书中国大百科全书-天文卷
浙富控股A股股东户数增加220... 7月7日消息,数据显示,截至2025年6月30日,浙富控股A股股东总户数为9.48万户,较上期(20...
ST路通A股股东户数增加100... 7月7日消息,数据显示,截至2025年6月30日,ST路通(维权)A股股东总户数为6500户,较上期...
绿茵逐梦,点亮未来 —— 华贸... 转自:扬子晚报今夏,华贸公益基金会与爱德基金会合作,邀请“少年足球梦”受助儿童走进南京和苏州,体验江...
70年代家庭教育故事? 70年代家庭教育故事?我们那时家庭教育父母总是让吃穿节省节约,奉行新三年,旧三年,缝缝补补又三年。
台风“丹娜丝”送清凉,江苏淮河... 转自:扬子晚报扬子晚报7月7日讯(记者 万惠娟)7日是小暑节气,小暑的到来标志我国大部分地区进入炎热...
儿童亡羊补牢怎么画 儿童亡羊补牢怎么画儿童亡羊补牢画法如下:1、先画牧童的头发和脸。2、再画牧童的眼睛。3、再画牧童的一...