算法练习题06:leetcode793每日温度

单调栈解法

复制代码
class Solution {
    public int[] dailyTemperatures(int[] temperatures) {
        int length = temperatures.length;
        int[] ans = new int[length];
        Stack<Integer> stack = new Stack<>();
        for(int i = 0;i<length;i++){
            int temperature = temperatures[i];
            while(!stack.isEmpty()&&temperature>temperatures[stack.peek()]){
                int pre = stack.pop();
                ans[pre] = i - pre;
            }
            stack.push(i);
        }
        return ans;
    }
}

不管咋样反正栈为空就先入栈,然后栈中存的是数组中数的索引,遍历这个数组,如果下一个数字比栈顶索引在数组中的值小,那么继续push压入栈,反之,下一个数字比栈顶索引在数组中的值大,那么就达成我们的目的了,找到比栈顶大的数了,那么pop弹出栈顶,i与弹出的那个索引做差值,就是弹出元素索引处的目标值,就是我们要的。画图看的更清楚。

相关推荐
真上帝的左手12 小时前
3. 代码管理-构建工具-Maven
java·maven
JIngJaneIL12 小时前
基于Java旅游信息推荐系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·旅游
梦未12 小时前
Java多态性与类生命周期
java
CryptoRzz12 小时前
对接印度股票市场数据 (India api) 实时k线图表
java·开发语言·python·区块链·maven
小李小李快乐不已12 小时前
哈希表理论基础
数据结构·c++·哈希算法·散列表
AuroraWanderll12 小时前
C++11(二)核心突破:右值引用与移动语义(上)
c语言·数据结构·c++·算法·stl
CoderYanger12 小时前
第 479 场周赛Q1——3769. 二进制反射排序
java·数据结构·算法·leetcode·职场和发展
广府早茶12 小时前
机器人重量
c++·算法
程序员岳焱12 小时前
Java 调用 DeepSeek API 的 8 个高频坑
java·人工智能·后端
sin_hielo12 小时前
leetcode 1925
数据结构·算法·leetcode