当前位置: 首页 > article >正文

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)。

代码

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;
    }
};


http://www.kler.cn/a/464255.html

相关文章:

  • 【工具整理】WIN换MAC机器使用工具整理
  • SAP SD销售模块常见BAPI函数
  • 【ShuQiHere】使用 SCP 进行安全文件传输
  • Appium 2.0:移动自动化测试的革新之旅
  • DATACOM-DHCP-复习-实验
  • vscode代码AI插件Continue 安装与使用
  • 革新排版机产线:一体式IO模块引领自动化高效控制新时代
  • orm03
  • js 文档注释
  • springboot实战(19)(条件分页查询、PageHelper、MYBATIS动态SQL、mapper映射配置文件、自定义类封装分页查询数据集)
  • 2025-1-2-sklearn学习(30)模型选择与评估-验证曲线: 绘制分数以评估模型 真珠帘卷玉楼空,天淡银河垂地。
  • 基于BP训练深度学习模型(用于回归)以及验证误差值
  • A*算法与人工势场法结合的路径规划(附MATLAB源码)
  • 基于Matlab实现离散点云数据三维表面重构程序(源码+数据)
  • 设计模式-创建型模式-工厂方法模式详解
  • 线路板沉金厚度一般是多少?【新立电子】
  • 聊聊前端框架中的process.env,env的来源及优先级(next.js、vue-cli、vite)
  • C# 设计模式的六大原则(SOLID)
  • 解密人工智能:如何改变我们的工作与生活
  • transfomer深度学习实战水果识别
  • 爱死机第四季(秘密关卡)4KHDR国语字幕
  • 【C++】B2093 查找特定的值
  • C语言实现贪吃蛇游戏
  • Spring MVC的@ResponseBody与@RequestBody
  • 路由技术在网络中的作用及特点
  • 数据结构与算法学习笔记----快速幂