LeetCode 739. 每日温度

解题思路

单调栈的经典题型。

我们需要找到temperatures[i]的右边最近的小于temperatures[i]的值,所以就想到了单调栈。

相关代码

复制代码
class Solution {
    public int[] dailyTemperatures(int[] temperatures) {
        Stack<Integer> stack = new Stack<>();
        int res[] = new int[temperatures.length];
        int n = temperatures.length;
        for(int i=n-1;i>=0;i--){
            //进行筛选
            while(stack.isEmpty()==false&&temperatures[i]>=temperatures[stack.peek()]) stack.pop();
            if(stack.isEmpty()==true) res[i]=0;
            else res[i]=Math.abs(stack.peek()-i);
            stack.push(i);
        }
        return res;
    }
}
相关推荐
洛水水1 分钟前
【力扣100题】48.乘积最大子数组
算法·leetcode·职场和发展
小小de风呀1 分钟前
de风——【从零开始学C++】(七):string类详解
开发语言·c++·算法
YL200404261 分钟前
042将有序数组转换为二叉搜索树
数据结构·算法·leetcode
qq_296553276 分钟前
矩阵对角线遍历:从暴力到最优的优雅解法
数据结构·线性代数·算法·青少年编程·矩阵·深度优先遍历
洛水水6 分钟前
【力扣100题】50.最长有效括号
算法·leetcode·职场和发展
数智工坊7 分钟前
【BLIP论文阅读】:统一视觉语言理解与生成的自举式预训练范式
论文阅读·人工智能·深度学习·算法·transformer
yyy(十一月限定版)8 分钟前
问题解决策略搜索训练3
算法
吃好睡好便好10 分钟前
在Matlab中绘制圆锥三维曲面图
开发语言·人工智能·学习·算法·matlab·信息可视化
兰令水11 分钟前
topcode【随机算法题】【2026.5.15打卡-java版本】
java·算法·leetcode
洛水水12 分钟前
【力扣100题】44.完全平方数
算法·leetcode·职场和发展