力扣 hot100 Day67

739. 每日温度

给定一个整数数组 temperatures ,表示每天的温度,返回一个数组 answer ,其中 answer[i] 是指对于第 i 天,下一个更高温度出现在几天后。如果气温在这之后都不会升高,请在该位置用 0 来代替。

cpp 复制代码
//抄的
class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        int n = temperatures.size();
        vector<int> answer(n, 0);
        stack<int> stk; // 存储的是天数索引
        
        for (int i = 0; i < n; ++i) {
            // 当栈不为空且当前温度大于栈顶那天的温度时
            while (!stk.empty() && temperatures[i] > temperatures[stk.top()]) {
                int prev_day = stk.top();
                stk.pop();
                answer[prev_day] = i - prev_day; // 计算天数差
            }
            stk.push(i); // 压入当前天数
        }
        
        return answer;
    }
};

stk是一个单调栈,索引对应温度值栈底至栈顶递增,具体逻辑如下

当栈为空或者当前天数温度小于栈顶值时,说明当前温度还不够高,不能解决任何等待中的天数的需求,所以直接推入当前天数;当当前天数大于栈顶值时,说明正是栈顶天数想要的,此时pop,保存数据,并循环判断,最后同样要压入当前天数。

可以这样理解,压栈是为了保存过去的数据,后续找到想找到值才让其出栈,通过维持一个单调栈,动态记录结果。

相关推荐
m0_715575341 分钟前
分布式任务调度系统
开发语言·c++·算法
测试涛叔18 分钟前
金三银四软件测试面试题(800道)
软件测试·面试·职场和发展
naruto_lnq23 分钟前
泛型编程与STL设计思想
开发语言·c++·算法
踩坑记录38 分钟前
leetcode hot100 94. 二叉树的中序遍历 easy 递归 dfs
leetcode
zxsz_com_cn43 分钟前
设备预测性维护算法分类及优劣势分析,选型指南来了
算法·分类·数据挖掘
Angelina_Jolie1 小时前
一文搞懂 SCI、SSCI、CSSCI、C 刊、核心期刊:定义、作用、层级对比及投稿选择
考研·职场和发展·创业创新
m0_748708051 小时前
C++中的观察者模式实战
开发语言·c++·算法
然哥依旧1 小时前
【轴承故障诊断】基于融合鱼鹰和柯西变异的麻雀优化算法OCSSA-VMD-CNN-BILSTM轴承诊断研究【西储大学数据】(Matlab代码实现)
算法·支持向量机·matlab·cnn
qq_537562671 小时前
跨语言调用C++接口
开发语言·c++·算法