栈练习--------(LeetCode 739-每日温度)

题目:点这里

解法

cpp 复制代码
class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        vector<int> ans;
        vector<int> stc;
        for(int i=0;i<temperatures.size();i++){
            ans.push_back(0);
        }
        for(int i=0;i<temperatures.size();i++){
            while(stc.size()&&temperatures[stc.back()]<temperatures[i]){
                ans[stc.back()] = i-stc.back();
                stc.pop_back();    
            }   
            stc.push_back(i);
        }
        return ans; 
    }
};

这个题目我又一次被栈这个容器的神奇所深深吸引,栈这个容器真是太有魅力了,同样的一道题目,用循环需要双层嵌套,代码又长又臭,而且会超时,用栈的话巧妙解决这个问题。

具体思路就是,首先定义两个栈,一个用来存放最终的答案,一个用来暂存需要比较元素的索引,第一步咱们将答案栈的所有值赋值为0,然后利用for循环的遍历,先将第一个元素,暂存入stc栈中,然后将温度数组中的后续元素与之比较,如若大于,则将两元素索引差传入答案栈,并且弹出stc栈的栈顶元素,否则将其传入stc栈中,紧接着进入下一层循环,再将stc栈的栈顶元素与后续元素进行比较,与前面重复相同的操作。

图示

但我学到的不只有这些。。。

反思

首先这一大段复杂的难以理解的代码不是一气呵成的,它需要我们结合图像分析,并生成初步的,不完善的一次性代码,后续再进行优化,比如:如果if语句和对应的else语句中都存在相同的语句,则就可以把这个重复语句提出来,放在判断的外面 ,另外,我总感觉栈配合循环 能爆发出无限的潜能,但我现在还不能想像出来,但这个题目给了我一点启发,栈配合循环使用的情形,如果一开始想象不到,可以把栈当作一个缓存的变量使用,结合判断,先写执行一次的特殊性代码,然后再转化成普遍性代码,这个就是从个性到共性,从特殊性到普遍性的道理。

还有,

ret.push_back()代表从尾部插入即入栈

ret.back()代表返回尾部元素即返回栈顶元素

ret.pop_back()代表删除尾部元素即出栈

相关推荐
☆5668 分钟前
C++中的命令模式
开发语言·c++·算法
仰泳的熊猫9 分钟前
题目2577:蓝桥杯2020年第十一届省赛真题-走方格
数据结构·c++·算法·蓝桥杯
CoovallyAIHub39 分钟前
Pipecat:构建实时语音 AI Agent 的开源编排框架,500ms 级端到端延迟
深度学习·算法·计算机视觉
灰色小旋风43 分钟前
力扣13 罗马数字转整数
数据结构·c++·算法·leetcode
2301_810160951 小时前
C++与物联网开发
开发语言·c++·算法
cm6543201 小时前
基于C++的操作系统开发
开发语言·c++·算法
ArturiaZ1 小时前
【day57】
开发语言·c++·算法
CoovallyAIHub1 小时前
Energies | 8版YOLO对8版Transformer实测光伏缺陷检测,RF-DETR-Small综合胜出
深度学习·算法·计算机视觉
Emberone1 小时前
排序:万物皆有序
算法·排序算法
其实秋天的枫1 小时前
2025年12月英语六级真题及答案解析完整版(第一、二、三套全PDF)
经验分享·算法