leetcode 739 单调栈模板题

单调栈的主要应用场景:即找左边或右边第一个大于/小于自身的元素,可以说课这个题一模一样。栈中元素永远递减,当遇到大的,就一致排出,保持递减性

其中一类单调栈的核心:当打破单调性的新元素出现时,旧元素的值可以被确定。

cpp 复制代码
typedef pair<int, int> P;

class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        int n = temperatures.size();
        vector<int> ans(n, 0);
        vector<P> st{P(INT_MAX, -1)};

        for(int i=0;i<n;i++)
        {
            int temp = temperatures[i];
            while(temp > st.back().first)
            {
                int pos = st.back().second;
                ans[pos] = i - pos;
                st.pop_back();
            }
            st.push_back(P(temp, i));
        }

        return ans;
    }
};
相关推荐
6Hzlia15 小时前
【Hot 100 刷题计划】 LeetCode 739. 每日温度 | C++ 逆序单调栈
c++·算法·leetcode
良木生香16 小时前
【C++初阶】:STL——String从入门到应用完全指南(1)
c语言·开发语言·数据结构·c++·算法
XWalnut16 小时前
LeetCode刷题 day16
数据结构·算法·leetcode·链表·动态规划
foundbug99918 小时前
基于混合整数规划的电池容量优化 - MATLAB实现
数据结构·算法·matlab
chutao18 小时前
EasyPDF 转图片(EasyPdf2Image)—— 本地安全实用的PDF与图片双向互转工具
安全·职场和发展·pdf·创业创新·学习方法
海绵宝宝的月光宝盒19 小时前
2-非金属材料
经验分享·笔记·学习·其他·职场和发展·课程设计·制造
memcpy019 小时前
LeetCode 2452. 距离字典两次编辑以内的单词【暴力;字典树】中等
算法·leetcode·职场和发展
王老师青少年编程20 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【排序贪心】:魔法
c++·算法·贪心·csp·信奥赛·排序贪心·魔法
wearegogog12320 小时前
基于和差波束法的单脉冲测角MATLAB实现
人工智能·算法·matlab