Leetcode739.每日温度(HOT100)

链接

第一次暴力提交错误,超时了:

cpp 复制代码
class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        int n = temperatures.size();
        vector<int> res(n,0);
        for(int i = 0;i<n;i++){
            int j = i+1;
            while(j<n){
                if(temperatures[j]>temperatures[i]){
                    res[i] = j-i;
                    break;
                }
                else{
                    ++j;
                }
            }
        }
        return res;
    }
};

强大的数据:

第二次正确提交:

cpp 复制代码
class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        vector<int> res(temperatures.size());
        stack<int> s;
        for(int i = temperatures.size()-1;i>=0;i--){
            while(s.size()&&temperatures[i]>=temperatures[s.top()]){
                s.pop();
            }
            if(s.size()){
                res[i] = s.top()-i;
            }
            s.push(i);
        }
        return res;
    }
};

注意:s是一个栈,里面存储的是下标,不是温度。这个题是单调栈的模板题。

单调栈其实就是对于暴力做法的优化,第一个优化:本来遍历到 i 时,你要利用for循环去右边遍历到比你大的元素,现在不用了,我们一开始就从右边起手,然后把 子数组全部存起来,这样遍历到 i 的时候,你在栈里找你要的答案就行了。这还不够,因为本质还是和for循环一样的。

所以第二个优化:遍历到 j 时,我们就判断,栈顶元素与 j 之间的大小,如果 j 大于等于栈顶元素的话,那就应该删掉栈顶元素,为什么?因为 j 比你栈顶有先发优势,人家下标更小,更受左边的 i 的青睐,你栈顶元素虽然有可能比 i 大,但是架不住 j 离得近,近水楼台先得月!

这就是单调栈,对于两层for 循环的优化。

单调栈讲解

相关推荐
vyuvyucd16 小时前
C++引用:高效编程的别名利器
算法
鱼跃鹰飞16 小时前
Leetcode1891:割绳子
数据结构·算法
️停云️16 小时前
【滑动窗口与双指针】不定长滑动窗口
c++·算法·leetcode·剪枝·哈希
码农小韩17 小时前
基于Linux的C++学习——指针
linux·开发语言·c++·学习·算法
wen__xvn17 小时前
第 34 场 蓝桥·算法入门赛·百校联赛
算法
ASD125478acx17 小时前
超声心动图心脏自动检测YOLO11-NetBifPN算法实现与优化
算法
无限进步_18 小时前
【C语言&数据结构】对称二叉树:镜像世界的递归探索
c语言·开发语言·数据结构·c++·git·算法·visual studio
星辞树18 小时前
揭秘阿里 DIN:当深度学习遇上“千物千面”
算法
刘立军19 小时前
如何选择FAISS的索引类型
人工智能·算法·架构
小芒果_0119 小时前
整理归并排序
c++·算法·排序算法·信息学奥赛