LeetCode739:每日温度

题目描述

给定一个整数数组 temperatures ,表示每天的温度,返回一个数组 answer ,其中 answer[i] 是指对于第 i 天,下一个更高温度出现在几天后。如果气温在这之后都不会升高,请在该位置用 0 来代替。


解题思想

使用单调栈

代码

cpp 复制代码
/*
    通常是一维数组,要寻找任一个元素的右边或者左边第一个比自己大或者小的元素的位置,
    此时我们就要想到可以用单调栈了。时间复杂度为O(n)。

    当前元素如果比栈顶元素大:将栈内比当前元素小的弹出并计算记录,然后将该元素入栈
    当前元素 <= 栈顶顶元素:当前元素入栈
*/
class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        vector<int> res(temperatures.size());
        
        stack<int> stk;

        //放入栈中的是下标
        stk.push(0);
        for (int i = 1; i < temperatures.size(); i++) {
            {
                while (!stk.empty() && temperatures[i] > temperatures[stk.top()]) {
                    res[stk.top()] = i - stk.top();
                    stk.pop();
                }
                stk.push(i);
            }
        }
        
        return res;
    }
};
相关推荐
ccLianLian几秒前
leetcode-hot100
算法·leetcode·职场和发展
qq_148115372 分钟前
分布式系统容错设计
开发语言·c++·算法
m0_560396474 分钟前
C++中的享元模式
开发语言·c++·算法
左左右右左右摇晃7 分钟前
数据结构——数组
数据结构·笔记·算法
左左右右左右摇晃9 分钟前
数据结构——队列
数据结构
nainaire11 分钟前
速通LeetCode hot100——(1~9 哈希,双指针,滑动窗口)
c++·笔记·算法·leetcode
2501_9249526911 分钟前
分布式缓存一致性
开发语言·c++·算法
XiYang-DING1 小时前
【LeetCode】LCR 019. 验证回文串 II
算法·leetcode·职场和发展
灰色小旋风1 小时前
力扣18 四数之和(C++)
数据结构·算法·leetcode