LeetCode 739. 每日温度

解题思路

单调栈的经典题型。

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

相关代码

复制代码
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;
    }
}
相关推荐
代码中介商4 分钟前
LRU缓存算法:双向链表+哈希表实现
算法·链表·缓存
lqqjuly8 分钟前
计算理论—图灵机、复杂性、信息论与机器学习的理论基础
算法
Hiter_John21 分钟前
Golang的循环语句
开发语言·算法·golang
磊 子30 分钟前
STL算法库讲解1
开发语言·c++·算法
8Qi831 分钟前
LeetCode 474:一和零(Ones and Zeroes)—— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包
stolentime37 分钟前
CF2066D2 Club of Young Aircraft Builders (hard version)题解
c++·算法·动态规划·组合数学
一个不知名程序员www43 分钟前
算法学习入门---算法题DAY3
c++·算法
七夜zippoe44 分钟前
DolphinDB向量化计算:高性能数据处理
算法·dolphindb
悠仁さん1 小时前
哈夫曼树的简单介绍
算法
bIo7lyA8v1 小时前
算法与数据结构协同优化的设计思想的技术8
数据结构·算法