【leetcode hot 100 739】每日温度

解法一:暴力解法

java 复制代码
class Solution {
    public int[] dailyTemperatures(int[] temperatures) {
        int n=temperatures.length;   // 指向要找下一个更高温度的地方
        int[] result = new int[n];
        for(int left=0;left<n;left++){
            int right=left+1;  // 指向正在找最高温度的地方
            while(right<n){
                if(temperatures[left]<temperatures[right]){
                    result[left]=right-left;
                    break;
                }
                else{
                    right++;
                }
            }
        }
        return result;
    }
}

错误原因:

解法二:单调栈

  • 当 i=0 时,单调栈为空,因此将 0 进栈。

    • stack=0(73)

    • ans=0,0,0,0,0,0,0,0

  • 当 i=1 时,由于 74 大于 73,因此移除栈顶元素 0,赋值 ans0:=1−0,将 1 进栈。

    • stack=1(74)

    • ans=1,0,0,0,0,0,0,0

  • 当 i=2 时,由于 75 大于 74,因此移除栈顶元素 1,赋值 ans1:=2−1,将 2 进栈。

    • stack=2(75)

    • ans=1,1,0,0,0,0,0,0

  • 当 i=3 时,由于 71 小于 75,因此将 3 进栈。

    • stack=2(75),3(71)

    • ans=1,1,0,0,0,0,0,0

  • 当 i=4 时,由于 69 小于 71,因此将 4 进栈。

    • stack=2(75),3(71),4(69)

    • ans=1,1,0,0,0,0,0,0

  • 当 i=5 时,由于 72 大于 69 和 71,因此依次移除栈顶元素 4 和 3,赋值 ans4:=5−4 和 ans3:=5−3,将 5 进栈。

    • stack=2(75),5(72)

    • ans=1,1,0,2,1,0,0,0

  • 当 i=6 时,由于 76 大于 72 和 75,因此依次移除栈顶元素 5 和 2,赋值 ans5:=6−5 和 ans2:=6−2,将 6 进栈。

    • stack=6(76)

    • ans=1,1,4,2,1,1,0,0

  • 当 i=7 时,由于 73 小于 76,因此将 7 进栈。

    • stack=6(76),7(73)

    • ans=1,1,4,2,1,1,0,0

java 复制代码
class Solution {
    public int[] dailyTemperatures(int[] temperatures) {
        int n = temperatures.length; // 指向要找下一个更高温度的地方
        int[] result = new int[n];
        Deque<Integer> stack = new LinkedList<>();
        for (int i = 0; i < n; i++) {
            while(!stack.isEmpty() && temperatures[i]>temperatures[stack.peek()]){
                int temp = stack.pop();
                result[temp] = i-temp;
            }
            stack.push(i);
        }
        return result;
    }
}
相关推荐
北域码匠2 分钟前
奇偶归并排序:并行计算的排序利器
数据结构·算法·c#·排序算法
成都易yisdong11 分钟前
上海某平面坐标系与CGCS2000坐标互转详解(含全域拟合点、实战案例、保密规范)
大数据·人工智能·算法
2601_9618451523 分钟前
花生十三网课网盘|百度网盘|下载
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划
快手技术28 分钟前
征集令|快手探索者LLM-Rec挑战赛正式发布!
算法
Yvonne爱编码44 分钟前
JAVA EE初阶---DAY 2 计算机网络
java·开发语言·计算机网络·算法·java-ee·php
workflower1 小时前
基于机器学习的设备故障预测分析方法
人工智能·算法·机器学习·设计模式·语言模型·自然语言处理·重构
格发许可优化管理系统1 小时前
Mentor许可证与其他软件许可证的深度比较
java·大数据·运维·c语言·c++·算法
wjcroom1 小时前
时空和电子7-泡力模型含罗量
人工智能·算法·机器学习
KaMeidebaby1 小时前
卡梅德生物技术快报 | Fab 合成文库构建与抗体筛选实验流程及数据解析
人工智能·python·tcp/ip·算法·机器学习
金融小师妹1 小时前
基于AI事件驱动模型与验证溢价框架的市场分析:从预期交易到事实验证,原油与黄金面临关键定价重构
大数据·人工智能·算法·均值算法·线性回归