leetcode 739. 每日温度

题目

核心思路(单调递减栈)

栈的作用 :存储温度数组的索引,且栈内索引对应的温度值保持单调递减。
遍历逻辑

  • 遍历每个温度时,若当前温度 > 栈顶索引的温度 → 栈顶索引的 "下一个更高温度" 就是当前索引,计算距离并弹出栈顶。
  • 重复上述过程直到栈为空 / 当前温度 ≤ 栈顶温度,再将当前索引压入栈。
  • 未找到更高温度的元素:栈中剩余索引(右侧无更高温度),结果置 0。

Java代码实现

java 复制代码
class Solution {
    public int[] dailyTemperatures(int[] temperatures) {
        Deque<Integer> stack = new LinkedList<>();
        int n = temperatures.length;
        int[] ans = new int[n];

        for (int i = 0; i < n; i++) {
            int t = temperatures[i];
            while (!stack.isEmpty() && t > temperatures[stack.peek()]) {
                int idx = stack.pop();
                ans[idx] = i - idx;
            }
            stack.push(i);
        }
        return ans;
    }
}

复杂度分析

  • 时间复杂度:O (n)。每个元素仅入栈和出栈一次,总操作次数为 2n。
  • 空间复杂度:O (n)。最坏情况下(温度严格递减),栈存储所有索引。
相关推荐
云烟成雨TD16 小时前
Spring AI Alibaba 1.x 系列【6】ReactAgent 同步执行 & 流式执行
java·人工智能·spring
小O的算法实验室16 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
于慨16 小时前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
swg32132116 小时前
Spring Boot 3.X Oauth2 认证服务与资源服务
java·spring boot·后端
gelald17 小时前
SpringBoot - 自动配置原理
java·spring boot·后端
殷紫川17 小时前
深入理解 AQS:从架构到实现,解锁 Java 并发编程的核心密钥
java
一轮弯弯的明月17 小时前
贝尔数求集合划分方案总数
java·笔记·蓝桥杯·学习心得
chenjingming66617 小时前
jmeter线程组设置以及串行和并行设置
java·开发语言·jmeter
殷紫川17 小时前
深入拆解 Java volatile:从内存屏障到无锁编程的实战指南
java
eddieHoo17 小时前
查看 Tomcat 的堆内存参数
java·tomcat