Leetcode面试经典150题-739.每日温度

应读者私信要求,本题协商题目的具体内容

给定一个整数数组 temperatures ,表示每天的温度,返回一个数组 answer ,其中 answer[i] 是指对于第 i 天,下一个更高温度出现在几天后。如果气温在这之后都不会升高,请在该位置用 0 来代替。

示例 1:

复制代码
输入: temperatures = [73,74,75,71,69,72,76,73]
输出: [1,1,4,2,1,1,0,0]

示例 2:

复制代码
输入: temperatures = [30,40,50,60]
输出: [1,1,1,0]

示例 3:

复制代码
输入: temperatures = [30,60,90]
输出: [1,1,0]

其他的就不多说了,上代码,看不懂的请留言或者私信,收到第一时间解答

java 复制代码
class Solution {
    /**题目是再简单不过的单调栈问题,而且和我们以前单调栈不同的是,这个只是求后面的
    所以我们只需要定义一位数组就可以了,其他的边写边解释吧
    这里要特别注意的是题目求的是下一个更高温出现在几天后,而不是出现在第几天,这明显就是一个陷阱
    解题的时候千万注意 */
    public int[] dailyTemperatures2(int[] temperatures) {
        /**如果就给了一天,那没有后面的天了,按题目要求返回0 */
        if(temperatures.length == 1) {
            return new int[]{0};
        }
        /**定义结果数组*/
        int[] ans = new int[temperatures.length];
        /**定义单调栈,栈里放的元素从底到顶越来越小,如果出现更大的就把栈里比它小的全部弹出
        注意栈里放的是下标*/
        Stack<Integer> minStack = new Stack<>();
        minStack.push(0);
        for(int i = 0; i < temperatures.length; i++) {
            while(!minStack.isEmpty() && temperatures[minStack.peek()] < temperatures[i]) {
                /**比它小的都弹出*/
                int popIndex = minStack.pop();
                /**是因为i的出现导致了popIndex位置的数弹出,所以i是右边第一个比它大的 */
                ans[popIndex] = i - popIndex;
            }
            minStack.push(i);
            /**次数比之前单调栈的问题简答的是不用再把栈里的弹空算每个对应的值,因为剩下的都是大的,右边没有比他大的
            题目规定没有比他大的就写0,所以这里直接省略了 */
        }
        return ans;
    }

    /**题目有点恶心,竟然只战胜40%的人,但是时间复杂度确实是O(n),我这里突然纠结了一下
    决定给他改了,不就是因为用了系统的栈吗我不用还不行吗 */
    public int[] dailyTemperatures(int[] temperatures) {
        /**如果就给了一天,那没有后面的天了,按题目要求返回0 */
        if(temperatures.length == 1) {
            return new int[]{0};
        }
        /**定义结果数组*/
        int[] ans = new int[temperatures.length];
        /**定义单调栈,栈里放的元素从底到顶越来越小,如果出现更大的就把栈里比它小的全部弹出
        注意栈里放的是下标*/
        int[] minStack = new int[temperatures.length];
        minStack[0] = 0;
        /**栈目前的有效长度 */
        int validLen = 1;
        for(int i = 0; i < temperatures.length; i++) {
            while(validLen != 0 && temperatures[minStack[validLen - 1]] < temperatures[i]) {
                /**比它小的都弹出*/
                int popIndex = minStack[--validLen];
                /**是因为i的出现导致了popIndex位置的数弹出,所以i是右边第一个比它大的 */
                ans[popIndex] = i - popIndex;
            }
            minStack[validLen++] = i;
            /**次数比之前单调栈的问题简答的是不用再把栈里的弹空算每个对应的值,因为剩下的都是大的,右边没有比他大的
            题目规定没有比他大的就写0,所以这里直接省略了 */
        }
        return ans;
    }
}

本来就是最优解了,但是竟然让我超过了40%的人,今天我是看不多去了,直接在常数时间了又改进了一把,也许仅此一次,下次不搞了,毕竟我们做算法看时间复杂度和空间复杂度,不看常数时间,非重点公司,我都懒得给他们改

这结果面试官大哥满意吗。。。

相关推荐
折哥的程序人生 · 物流技术专研6 小时前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
程序员二叉6 小时前
【Java】 异常高频面试题精讲 | 易错点+对比总结
java·开发语言·面试
想吃火锅10057 小时前
【leetcode】14.最长公共前缀js
算法·leetcode·职场和发展
云絮.8 小时前
数据库操作
数据库·mysql·算法·oracle
小林ixn8 小时前
LeetCode 206. 反转链表(迭代 + 递归详解)
算法·leetcode·链表
凡人叶枫9 小时前
Effective C++ 条款17:以独立语句将 newed 对象置入智能指针
java·linux·开发语言·c++·算法
菜鸟‍10 小时前
LeetCode 1 27 和 704 || 两数之和 移除元素 二分查找
算法·leetcode·职场和发展
weixin_5231853210 小时前
Java面试高频题:Integer缓存机制与 equals、== 区别
java·缓存·面试
退休倒计时11 小时前
【每日一题】LeetCode 142. 环形链表 II TypeScript
算法·leetcode·链表·typescript
popcorn_min11 小时前
Digits 手写数字识别:随机森林多分类 + 像素级特征热力图
算法·随机森林·分类