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;
    }
};
相关推荐
小王努力学编程1 分钟前
LangChain——AI应用开发框架(核心组件1)
linux·服务器·前端·数据库·c++·人工智能·langchain
庄小焱6 分钟前
【机器学习】——房屋销售价格预测实战
人工智能·算法·机器学习·预测模型
txzrxz11 分钟前
单调栈详解(含题目)
数据结构·c++·算法·前缀和·单调栈
AI科技星24 分钟前
张祥前统一场论的数学表述与概念梳理:从几何公设到统一场方程
人工智能·线性代数·算法·机器学习·矩阵·数据挖掘
程序员-King.31 分钟前
day167—递归—二叉树的直径(LeetCode-543)
算法·leetcode·深度优先·递归
亲爱的非洲野猪34 分钟前
2动态规划进阶:背包问题详解与实战
算法·动态规划·代理模式
Trouvaille ~1 小时前
【Linux】进程间通信(二):命名管道与进程池架构实战
linux·c++·chrome·架构·进程间通信·命名管道·进程池
YH12312359h1 小时前
战斗机目标检测与跟踪:YOLOv26算法详解与应用
算法·yolo·目标检测
芒克芒克1 小时前
LeetCode 134. 加油站(O(n)时间+O(1)空间最优解)
java·算法·leetcode·职场和发展
HellowAmy1 小时前
我的C++规范 - 随机时间点
开发语言·c++·代码规范