news 2026/6/10 13:28:05

LeetCode热题100--739. 每日温度--中等

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode热题100--739. 每日温度--中等

题目

给定一个整数数组 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]

题解

classSolution{publicint[]dailyTemperatures(int[]T){intlength=T.length;int[]result=newint[length];//从右向左遍历for(inti=length-2;i>=0;i--){// j+= result[j]是利用已经有的结果进行跳跃for(intj=i+1;j<length;j+=result[j]){if(T[j]>T[i]){result[i]=j-i;break;}elseif(result[j]==0){//遇到0表示后面不会有更大的值,那当然当前值就应该也为0result[i]=0;break;}}}returnresult;}}

解析

出自:每日温度 - Java

publicint[]dailyTemperatures(int[]T){...}//定义一个方法,它接受一个整型数组并返回另一个整型数组。intlength=T.length;int[]result=newint[length];//初始化我们的"result"数组,并给它分配输入数据的大小和维度。for(inti=length-2;i>=0;i--){...}//我们反着读取我们的"T"数组,从最后一个元素到第一个。这是为了能够利用我们已经做过的计算来跳过我们不需要再次做的计算(例如在同一迭代中找出更大的值的检查和赋值)。for(intj=i+1;j<length;j+=result[j]){...}//这个循环试图找到T中的下一个较大的气温,它使用了我们已经计算过的值来跳过某些索引。我们每次增加`result[j]`是基于前面的结果(可能对同一迭代来说可能是零)if(T[j]>T[i]){...}//如果当前的'j'索引上的值大于我们的'i'索引,我们计算出间隔并将其赋给我们的result数组中的'i'索引。elseif(result[j]==0){...}//否则如果在接下来的索引上找不到更大的值(前面的循环已经处理了这个情况),我们认为该天的温度"没有等待更多的天数".returnresult;//这行代码完成整个函数。它将我们的结果数组作为输出返回给调用者。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 6:43:09

内存分配效率提升50%?.NET 9这3项优化你不可不知

第一章&#xff1a;.NET 9 的内存分配优化实践.NET 9 在运行时和编译器层面引入了多项改进&#xff0c;显著提升了内存分配效率&#xff0c;尤其在高吞吐场景下表现突出。通过减少临时对象的生成、优化垃圾回收&#xff08;GC&#xff09;频率以及增强 Span 和 ref struct 的使…

作者头像 李华
网站建设 2026/6/10 9:27:47

数据交易合规指南:国内外法律法规全景解读

数据交易合规指南:国内外法律法规全景解读 关键词:数据交易合规、个人信息保护、跨境数据流动、GDPR、数据安全法、CCPA、合规框架 摘要:本文系统解析数据交易领域的国内外核心法律法规,构建覆盖数据采集、处理、交易、跨境流动全生命周期的合规框架。通过对比欧盟GDPR、中…

作者头像 李华
网站建设 2026/6/10 9:27:47

干翻Dubbo系列第二篇:Dubbo3相对其他版本的升级

一&#xff1a;易用性1&#xff1a;支持语言Dubbo3支持更多的语言&#xff1a;Go、Rust、Python2&#xff1a;开箱急用开箱即用&#xff0c;如果后续我们基于Spring开发&#xff0c;就是配置几个Xml的事&#xff0c;如果是基于SpringBoot的话&#xff0c;就是打几个注解的事。二…

作者头像 李华
网站建设 2026/6/10 9:27:31

学习Java24天(练习)

import java.util.Random;public class Role {private String name;private int blood;private char gender;private String face;// 男性长相成语数组String[] boyfaces {"相貌堂堂", "眉清目秀", "气宇轩昂", "风度翩翩", "玉…

作者头像 李华