LeetCode:739. 每日温度

简介

题目链接:https://leetcode.cn/problems/daily-temperatures/description/

解决方式:数组 + 暴力枚举 / 单调栈

暴力枚举

思路:可以直接双重循环。外层循环迭代每一个元素,内层循环找到更高的温度。

java 复制代码
class Solution {
    public int[] dailyTemperatures(int[] temperatures) {
        int n = temperatures.length;
        int[] answer = new int[n];
        for (int i = 0; i < n; i++) {
            for (int j = i + 1; j < n; j++) {
                if (temperatures[j] > temperatures[i]) {
                    answer[i] = j - i;
                    // 找到一个直接迭代下一个元素
                    break;
                }
            }
        }
        // 返回结果
        return answer;
    }
}

单调栈

思路:暴力枚举的方式时间复杂度太高,我们可以借助栈实现一次遍历。维护一个单调递减的栈,从栈底到栈顶单调递减。迭代每一个元素,若当前元素比栈顶元素大,说明栈顶元素遇到下一个更高的温度,出栈并记录。继续比较新的栈顶与当前迭代元素,因为新的栈顶元素比原来的大,所以有可能比当前迭代元素大,也可能小,所以继续比较,看看谁大谁小,如此循环。

java 复制代码
class Solution {
    public int[] dailyTemperatures(int[] temperatures) {
        int n = temperatures.length;
        // 结果集合
        int[] answer = new int[n];
        // 单调递减栈(栈底 -> 栈顶)
        Deque<Integer> stack = new ArrayDeque<>();
        // 迭代
        for(int i = 0; i < n; i++){
            // 栈不为空且迭代元素比栈顶元素大,则栈顶元素出栈并标记遇到更大温度
            while(!stack.isEmpty() && temperatures[i] > temperatures[stack.peek()]){
                // 出栈
                int pindex = stack.pop();
                // 记录更高温度
                answer[pindex] = i - pindex; 
            }
            // 迭代元素入栈(索引)
            stack.push(i);
        }
        // 返回结果
        return answer;
    }
}
相关推荐
计算机安禾10 小时前
【算法分析与设计】第20篇:图论中的NP困难问题与近似策略
大数据·人工智能·算法
Trouvaille ~10 小时前
【优选算法篇】深入浅出链表算法:交换、重排与合并的终极策略
c++·算法·链表·面试·蓝桥杯·笔试·后端开发
Z_Wonderful10 小时前
大文件上传-分片上传-秒传
算法·哈希算法
heimeiyingwang10 小时前
【架构实战】分布式ID生成方案:雪花算法与业务ID设计
分布式·算法·架构
圣保罗的大教堂10 小时前
leetcode 3121. 统计特殊字母的数量 II 中等
leetcode
圣保罗的大教堂10 小时前
leetcode 3120. 统计特殊字母的数量 I 简单
leetcode
sheeta199811 小时前
LeetCode 每日一题笔记 日期:2026.05.28 题目:3093. 最长公共后缀查询
linux·笔记·leetcode
SoftLipaRZC11 小时前
C语言字符完全指南:字符函数与字符串函数
c语言·开发语言·算法
墨白曦煜11 小时前
算法实战笔记:链表的底层逻辑与指针的高阶玩法(二)
笔记·算法·链表