剑指Offer专项突破版(38)—— 每日温度

题目

剑指 Offer II 038. 每日温度

在这里插入图片描述

思路

本题需要用到单调栈的思想:

准备一个栈,从左往右遍历每个下标i,检查栈顶元素j代表的数arr[j]是否小于arr[i]

  • 如果小于,将栈顶元素j弹出,直到栈顶元素大于等于arr[i],或栈为空位置

    • 将栈顶元素j弹出时,位置j代表的数需要等待的天数就为i - j
  • 如果大于,则将下标i压入栈中,继续看下一个数

当遍历完成时,栈中剩下的数中,由于右边没有比这些数更大的数,因此需要等待的天数为0

我们来看为什么这样做正确:

  • 结论:当arr[i] > arr[j]导致j被弹出时时,i一定是j右边,第一个比j大的数
  • 证明:根据规则,每个数与将栈顶所有小于当前的数的数都弹出,然后把自己压入栈中,形成一个从大到小(从栈底到栈顶)的单调栈。那么如果i不是j右边第一个比j大的数,j会在之前遇到第一个比j大的数时就被弹出,而不会等到遇到i时才被弹出

代码


public int[] dailyTemperatures(int[] temperatures) {
    Stack<Integer> stack = new Stack<>();
    int[] res = new int[temperatures.length];
    for (int i = 0;i<temperatures.length;i++) {
        while (!stack.isEmpty() && temperatures[i] > temperatures[stack.peek()]) {
            // 结算j
            res[stack.peek()] = i - stack.peek();
            // 弹出j
            stack.pop();
        }
        
        // 将i压入栈中 
        stack.push(i);
    }
    
    return res;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值