LeetCode 739.每日温度

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

示例 1:

输入: temperatures = 73,74,75,71,69,72,76,73

输出: 1,1,4,2,1,1,0,0

示例 2:

输入: temperatures = 30,40,50,60

输出: 1,1,1,0

示例 3:

输入: temperatures = 30,60,90

输出: 1,1,0

提示:

1 <= temperatures.length <= 10 5 ^5 5

30 <= temperaturesi <= 100

单调栈,从后往前遍历温度,每遍历到一个温度t,循环将其与栈顶温度比较,如果t大于等于栈顶温度,则出栈,这样栈顶的温度就是后面第一个大于当前的温度了:

cpp 复制代码
class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        int n = temperatures.size();
        vector<int> ans(n);

        stack<int> stk;
        for (int i = n - 1; i >= 0; --i) {
            while (!stk.empty() && temperatures[i] >= temperatures[stk.top()]) {
                stk.pop();
            }

            if (!stk.empty()) {
                ans[i] = stk.top() - i;
            }

            stk.push(i);
        }

        return ans;
    }
};

如果temperatures的长度为n,则此算法时间复杂度为O(n),空间复杂度为O(n)。

相关推荐
计算机安禾13 小时前
【算法分析与设计】第36篇:计算几何基础:凸包问题的分治与扫描线解法
大数据·人工智能·算法·机器学习·剪枝
货拉拉技术13 小时前
飞速发展的计算机视觉
人工智能·算法
如竟没有火炬13 小时前
寻找峰值——二分
java·开发语言·数据结构·python·算法·散列表
noipp13 小时前
推荐题目:洛谷 P1115 最大子段和
算法
Lumbrologist13 小时前
【C++】零基础入门 · 第 17 节:多线程编程基础
java·c++·算法
轻闲一号机14 小时前
【语音】笔记
前端·笔记·算法
aWty_14 小时前
实分析入门(12)--可测函数
学习·数学·算法·实变函数
海砥装备HardAus14 小时前
无人机姿态解算中「重力矢量观测退化」机理与动态补偿技术
算法·无人机·飞控
广州灵眸科技有限公司14 小时前
瑞芯微RV1126B开发板(EASY-EAI-PI2) 开发套件组装上电
网络·数据库·人工智能·算法·飞书
SuperHeroWu714 小时前
【算法】强化学习中奖励和损失函数的关系
算法·环境·强化学习·损失函数·奖励