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

力扣739. 每日温度

Problem: 739. 每日温度

文章目录

  • 题目描述
  • 思路
  • 复杂度
  • Code

题目描述

在这里插入图片描述

思路

若本题目使用暴力法则会超时,故而使用单调栈解决:

1.创建结果数组res,和单调栈stack;
2.循环遍历数组temperatures:

2.1.若当stack不为空同时栈顶所存储的索引对应的气温小于当前的气温,则跟新res中对应位置的值;
2.2.每次向stack中存入每日气温的索引下标

复杂度

时间复杂度:

O ( n ) O(n) O(n);其中 n n n是数组temperatures的大小

空间复杂度:

O ( n ) O(n) O(n)

Code

class Solution {/*** Daily Temperatures** @param temperatures Given array* @return int[]*/public int[] dailyTemperatures(int[] temperatures) {int n = temperatures.length;Stack<Integer> stack = new Stack<>();int[] res = new int[n];for (int i = n - 1; i >= 0; --i) {while (!stack.isEmpty() && temperatures[stack.peek()] <= temperatures[i]) {stack.pop();}res[i] = stack.isEmpty() ? 0 : stack.peek() - i;stack.push(i);}return res;}
}
http://www.lryc.cn/news/354377.html

相关文章:

  • KDE6桌面于2024年2月发布
  • 「TypeScript系列」TypeScript 对象及对象的使用场景
  • shell从入门到精通(22)shell正则匹配~=
  • 【Spring】使用Spring常用导入依赖介绍
  • PC端应用订阅SDK接入攻略
  • WebService的wsdl详解
  • 数据分析实战:从0到1完成数据获取分析到可视化
  • 【Spring】深入理解 Spring 中的 ImportSelector、Aware 和 Processor 接口
  • 【C语言】strstr函数的使用和模拟
  • 五分钟”手撕“异常
  • 【vue3+elementuiplus】el-select下拉框会自动触发校验规则
  • 【论文复现】LSTM长短记忆网络
  • 目标检测YOLO实战应用案例100讲-【自动驾驶】激光雷达
  • 用C语言设计轨道电机的驱动库
  • HTML跳动的爱心
  • 汇编原理(二)
  • Android Studio开发之路(十三)主题影响Button颜色问题解决及button自定义样式
  • eNSP学习——OSPF单区域配置
  • 深度学习中的优化算法二(Pytorch 19)
  • R实验 方差分析
  • AI智能体|手把手教你使用扣子Coze图像流的文生图功能
  • 应用程序图标提取
  • Excel表格在线解密:轻松解密密码,快速恢复数据
  • springboot小结1
  • 【Qt 学习笔记】Qt窗口 | 菜单栏 | QMenuBar的使用及说明
  • Spark运行模式详解
  • vcpkg环境配置
  • python学习:基础语句
  • Nginx限制IP访问详解
  • Three.js——二维平面、二维圆、自定义二维图形、立方体、球体、圆柱体、圆环、扭结、多面体、文字