leetcode热题100(739. 每日温度)单调栈c++

链接:739. 每日温度 - 力扣(LeetCode)

给定一个整数数组 temperatures ,表示每天的温度,返回一个数组 answer ,其中 answer[i] 是指对于第 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 <= 105
  • 30 <= temperatures[i] <= 100

题意

求数组a[i]的a[j](a[j]>a[i])相隔多少个位置 j-i,没有比他大的就输出0、

思路

因为我们要求的是比当前元素大位置,那么我们可以倒序来求一个单调栈,从后往前记录一个单调递减的栈,那我们我们每到下一个位置的元素,我们就可以很快的找到比他大的第一个元素。然后得到的答案就是(栈顶-i)。

代码

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

        stack<int> st;
        vector<int> res;
        for(int i=n-1;i>=0;i--){
            while(st.size() && a[i]>=a[st.top()]) st.pop();
        
            if(st.size()) res.push_back(st.top()-i);
            else res.push_back(0);
            st.push(i);
        }
        reverse(res.begin(),res.end());
        return res;
    }
};
相关推荐
Y.O.U..几秒前
今日八股——C++
开发语言·c++·面试
SweetCode6 分钟前
裴蜀定理:整数解的奥秘
数据结构·python·线性代数·算法·机器学习
ゞ 正在缓冲99%…19 分钟前
leetcode76.最小覆盖子串
java·算法·leetcode·字符串·双指针·滑动窗口
xuanjiong20 分钟前
纯个人整理,蓝桥杯使用的算法模板day2(0-1背包问题),手打个人理解注释,超全面,且均已验证成功(附带详细手写“模拟流程图”,全网首个
算法·蓝桥杯·动态规划
Zhichao_9737 分钟前
【UE5 C++课程系列笔记】33——商业化Json读写
c++·ue5
惊鸿.Jh39 分钟前
【滑动窗口】3254. 长度为 K 的子数组的能量值 I
数据结构·算法·leetcode
明灯L40 分钟前
《函数基础与内存机制深度剖析:从 return 语句到各类经典编程题详解》
经验分享·python·算法·链表·经典例题
碳基学AI1 小时前
哈尔滨工业大学DeepSeek公开课:探索大模型原理、技术与应用从GPT到DeepSeek|附视频与讲义免费下载方法
大数据·人工智能·python·gpt·算法·语言模型·集成学习
补三补四1 小时前
机器学习-聚类分析算法
人工智能·深度学习·算法·机器学习
独好紫罗兰1 小时前
洛谷题单3-P5718 【深基4.例2】找最小值-python-流程图重构
开发语言·python·算法