LeetCode 739. 每日温度

OJ链接: 739. 每日温度

示例代码:

复制代码
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 temp = temperatures[i]; 
           //当栈不为空 且 当前温度大于栈顶温度
                while( !stack.empty() && temp > temperatures[stack.peek()]){
    //出栈 ,并记录下标
                   int perv = stack.pop();
                    ans[perv] = i - perv;
                }
                stack.push(i);
            }
            return ans;
    }
}
相关推荐
minji...几秒前
Linux 基础IO(一) (C语言文件接口、系统调用文件调用接口open,write,close、文件fd)
linux·运维·服务器·网络·数据结构·c++
第二只羽毛17 分钟前
C++ 高性能编程要点
大数据·开发语言·c++·算法
geekmice23 分钟前
实现一个功能:springboot项目启动将controller地址拼接打印到txt文件
java·spring boot·后端
老华带你飞27 分钟前
旅游|基于Java旅游信息系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·旅游
CQ_YM43 分钟前
数据结构之栈
数据结构·算法·
小石头 100861 小时前
【JavaEE】进程和线程的区别
java·java-ee
爱学习的梵高先生1 小时前
C++:基础知识
开发语言·c++·算法
oioihoii1 小时前
C++对象生命周期与析构顺序深度解析
java·开发语言·c++
xlq223221 小时前
24.map set(下)
数据结构·c++·算法