栈练习--------(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()代表删除尾部元素即出栈

相关推荐
W230357657313 小时前
经典算法:最长上升子序列(LIS)深度解析 C++ 实现
开发语言·c++·算法
.Ashy.13 小时前
2026.4.11 蓝桥杯软件类C/C++ G组山东省赛 小记
c语言·c++·蓝桥杯
2401_8920709813 小时前
链栈(链式栈) 超详细实现(C 语言 + 逐行精讲)
c语言·数据结构·链栈
minji...14 小时前
Linux 线程同步与互斥(三) 生产者消费者模型,基于阻塞队列的生产者消费者模型的代码实现
linux·运维·服务器·开发语言·网络·c++·算法
语戚15 小时前
力扣 968. 监控二叉树 —— 贪心 & 树形 DP 双解法递归 + 非递归全解(Java 实现)
java·算法·leetcode·贪心算法·动态规划·力扣·
skywalker_1115 小时前
力扣hot100-7(接雨水),8(无重复字符的最长子串)
算法·leetcode·职场和发展
bIo7lyA8v16 小时前
算法稳定性分析中的输入扰动建模的技术9
算法
CoderCodingNo16 小时前
【GESP】C++三级真题 luogu-B4499, [GESP202603 三级] 二进制回文串
数据结构·c++·算法
sinat_2869451916 小时前
AI Coding 时代的 TDD:从理念到工程落地
人工智能·深度学习·算法·tdd