【LeetCode739】每日温度

news/2024/10/22 15:31:07/

1、题目描述

【题目链接】
给定一个整数数组 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

2、基本思路

 如果采用最简单最暴力的方法,就是从当前位置i的下一个位置i+1出发,找到第一个j,使得temperatures[j] > temperatures[i],这种方法最坏情况得时间复杂度为O(n^2)。那么,有没有更好得方法呢?答案是有的。
 采用单调栈的方法,维护一个从栈底到栈顶单调递减的序列,举个简单的例子,例如温度序列为【1,4,3,5,5,2,3,6】

  • 初始化,栈空;
  • 首先,栈空,1入栈(栈中元素[1]);
  • 第二个数4,与栈顶元素1比较,1<4,则出栈,且答案为res[1]=1,栈空结束比较,4入栈(栈中元素[4]);
  • 第三个数3,与栈顶元素4比较,4>3,3入栈;(栈中元素[4,3]);
  • 第四个数5,与栈顶元素3比较,3<5,3出栈,答案为res[3]=1;(栈中元素[4]);
  • 栈非空,继续与栈顶元素比较,4<5,4出战,答案为res[2]=2;(栈中元素[]);
  • 栈空,5入栈(栈中元素[5]);
  • 第五个元素5,与栈顶元素5比较,5>=5,5入栈,(栈中元素[5,5]);
  • 第六个元素2,与栈顶元素5比较,5>2,2入栈,(栈中元素[5,5,2]);
  • 第七个元素3,与栈顶元素2比较,2<3,2出栈,且答案为res[6]=1,(栈中元素[5,5]);
  • 栈非空,继续与栈顶元素5比较,5>3,3入栈,(栈中元素[5,5,3]);
  • 第八个元素6,与栈顶元素3比较,3<6,3出栈,且答案为res[7]=1,(栈中元素[5,5]);
  • 栈非空,与栈顶元素5比较,5<6,5出栈,且答案为res[4]=4,(栈中元素[5]);
  • 栈非空,与栈顶元素5比较,5<6,5出栈,且答案为res[5]=3,(栈中元素[]);
  • 栈为空且序列遍历结束
    最终答案为[1,2,1,4,3,1,1,0]

 同样,我们也可以维护一个从栈底到栈顶维护一个单调递减的序列,遍历的序列从右往左。

单调栈的基本思想——及时去掉无用的数据,保证栈中数据有序

3、代码实现

  • 方法一
vector<int> solve1(vector<int> &temperatures)
{int n = temperatures.size();vector<int> res(n,0);stack<int> st;for(int i =0;i<n;++i){int t = temperatures[i];while(!st.empty() && t> temperatures[st.top()]){res[st.top()] = i-st.top();st.pop() ;}st.push(i);}return res;}
  • 方法二
vector<int> solve(vector<int> &temperatures)
{int n = temperatures.size();vector<int> res(n,0);stack<int> st;for(int i =n-1;i>=0;i--){int t = temperatures[i];while(!st.empty() && t>=temperatures[st.top()]){st.pop();}if(!st.empty()){res[i] = st.top()-i;}st.push(i);}return res;}

http://www.ppmy.cn/news/1295626.html

相关文章

CodeWave智能开发平台--03--目标:应用创建--07供应商数据表格01

摘要 本文是网易数帆CodeWave智能开发平台系列的第09篇&#xff0c;主要介绍了基于CodeWave平台文档的新手入门进行学习&#xff0c;实现一个完整的应用&#xff0c;本文主要完成07供应商数据表格 CodeWave智能开发平台的09次接触 CodeWave参考资源 网易数帆CodeWave开发者…

【linux学习笔记】网络

目录 【linux学习笔记】网络检查、监测网络ping-向网络主机发送特殊数据包traceroute-跟踪网络数据包的传输路径netstat-检查网络设置及相关统计数据 【linux学习笔记】网络 检查、监测网络 ping-向网络主机发送特殊数据包 最基本的网络连接命令就是ping命令。ping命令会向指…

Linux丨查看当前目录下文件夹/文件大小,包括隐藏文件夹/文件

Author&#xff1a;AXYZdong 硕士在读 工科男 有一点思考&#xff0c;有一点想法&#xff0c;有一点理性&#xff01; 定个小小目标&#xff0c;努力成为习惯&#xff01;在最美的年华遇见更好的自己&#xff01; CSDNAXYZdong&#xff0c;CSDN首发&#xff0c;AXYZdong原创 唯…

SPRING BOOT发送邮件验证码(Gmail邮箱)

SPRING BOOT邮件发送验证码 一、Gmail邮箱配置 1、进入Gmail(https://mail.google.com) 2、打开谷歌右上角设置 3、启用POP/IMP 4、启用两步验证(https://myaccount.google.com/security) 5、建立应用程式密码 6、复制保存应用程式密码 二、代码 1、引入依赖 <d…

[SpringBoot]自定义注解@AutoFill,实现公共字段自动填充(避免重复对时间属性初始化

对于时间属性&#xff0c;如createTime、updateTime在进行插入、修改操作时都要一个个初始化处理&#xff0c;过于麻烦。 可以自定义注解AutoFill作用于INSERT&#xff0c;UPDATE操作方法上&#xff0c;再自定义切面类&#xff0c;统一拦截加入了AutoFill注解的方法&#xff0c…

Go语言中的init函数的执行时机

init函数的执行时机 这个涉及到 init 函数的作用和执行顺序相同个文件和不同文件中以及在不同的包中init的执行顺序go文件初始化的顺序 一、init 函数的作用和执行顺序 作用 init 函数是用于程序执行前做包的初始化的函数&#xff0c;比如初始化包里面的一些变量等等通常在…

UE5.1_UMG序列帧动画制作

UE5.1_UMG序列帧动画制作 UMG序列帧动画制作相对比较简单&#xff0c;不像视频帧需要创建媒体播放器那么复杂&#xff0c;以下简要说明&#xff1a; 1. 事件函数 2. 准备序列帧装入数组 3. 构造调用事件函数 4. 预览 序列帧UMG0105 5. 完成&#xff01;按需配置即可。

mysql服务多实例运行

1、官网下载mysql安装包 https://downloads.mysql.com/archives/community/ 2、解压安装包 tar -zxvf mysql-8.1.0-linux-glibc2.28-aarch64.tar.xz -C /usr/localmv /usr/local/mysql-8.1.0-linux-glibc2.28-aarch64 /usr/local/mysql 3、创建mysql用户组 groupadd…