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

每日温度00

题目链接

每日温度

题目描述

注意点

  • answer[i] 是指对于第 i 天,下一个更高温度出现在几天后
  • 如果气温在这之后都不会升高,请在该位置用 0 来代替
  • 1 <= temperatures.length <= 100000

解答思路

  • 使用单调栈解决本题,思路为:遍历整个数组,遍历到任意一个下标i元素时,如果当前栈不为空,则需要不断将栈顶元素弹出与temperatures[i]的值进行比较,直到栈为空或栈顶元素比temperatures[i]更大为止,当栈顶元素比temperatures[i]小更新对应栈顶元素下标的下一个更高温度出现在几天后,再比较过后需要将当前元素的下标i压入栈中

代码

class Solution {public int[] dailyTemperatures(int[] temperatures) {int n = temperatures.length;int[] res = new int[n];Deque<Integer> deque = new ArrayDeque<>();for (int i = 0; i < n; i++) {while (!deque.isEmpty() && temperatures[deque.peek()] < temperatures[i]) {int pre = deque.pop();res[pre] = i - pre;}deque.push(i);}return res;}
}

关键点

  • 单调栈的思路
  • answer[i] 是指对于第 i 天,下一个更高温度出现在几天后
http://www.lryc.cn/news/197308.html

相关文章:

  • 【JVM】JVM的垃圾回收机制
  • 28栈与队列-单调队列
  • qt软件崩溃的分析方法-定位源文件和行号
  • 《实验细节》上手使用PEFT库方法和常见出错问题
  • 软考高级系统架构论文 注意事项
  • Reasoning with Language Model Prompting: A Survey
  • jenkins pipeline使用
  • MATLAB——神经网络参考代码
  • 小程序搭建OA项目首页布局界面
  • HyperLogLog算法
  • 自定义Docker镜像--Jupyterlab
  • IDEA中明明导入jar包了,依旧报ClassNotFoundException
  • 【VIM TMUX】开发工具 Vim 在 bash 中的显示与 tmux 中的显示不同
  • 全网最全,Postman接口自动化测试实战整理,避开所有弯路...
  • 蓝桥杯双周赛算法心得——三带一(暴力枚举)
  • 【C++】适配器模式 - - stack/queue/deque
  • EKP接口开发Webservice服务和Restservice服务以及定时任务Demo
  • 如何确定IP地址的具体位置?
  • 软考-网络安全体系与网络安全模型
  • Java身份证OCR识别 - 阿里云API【识别准确率超过99%】
  • vue中获取复选框是否被选中的值、如何用JavaScript判断复选框是否被选中
  • Python学习之逻辑中的循环有哪些?
  • 【uniapp微信小程序+springBoot(binarywang)
  • 智能井盖的用处有哪些?好用在什么地方?
  • 微信小程序数据存储方式有哪些
  • FTC局部路径规划代码分析
  • SpringBoot集成Activiti7
  • 25.1 MySQL SELECT语句
  • 【VSCode】Windows环境下,VSCode 搭建 cmake 编译环境(通过配置文件配置)
  • useragent识别访问设备