代码随想录 打卡第四十七天

739 每日温度

cpp 复制代码
class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        vector<int> answers(temperatures.size(),0);
        stack<int> st;
        for(int i = 0;i < temperatures.size();i++){
            while(!st.empty()  && temperatures[i] > temperatures[st.top()]){
                answers[st.top()] = i - st.top();
                st.pop();
            }
            st.push(i);
        }
        return answers;
    }
};

496 下一个更大元素 I

cpp 复制代码
class Solution {
public:
    vector<int> nextGreaterElement(vector<int>& nums1, vector<int>& nums2) {
        vector<int> answer(nums1.size(),-1);
        stack<int> st;
        unordered_map<int,int> mp;
        for(int i = 0;i < nums1.size();i++){
            mp[nums1[i]] = i;
        }

        for(int i = 0;i < nums2.size();i++){
            while(!st.empty() && nums2[i] > st.top()){
                if(mp.find(st.top()) != mp.end()) answer[mp[st.top()]] = nums2[i];
                st.pop();
            }
            st.push(nums2[i]);
        }
        return answer;
    }
};

503 下一个更大元素 II

cpp 复制代码
class Solution {
public:
    vector<int> nextGreaterElements(vector<int>& nums) {
        vector<int> answer(nums.size(),-1);
        stack<int> st;
        for(int i = 0; i < 2 * nums.size();i++){
            while(!st.empty() && nums[i%nums.size()] > nums[st.top()]){
                answer[st.top()] = nums[i%nums.size()];
                st.pop();
            }
            st.push(i%nums.size());
        }
        return answer;
    }
};
相关推荐
cpp_25011 小时前
P10722 [GESP202406 六级] 二叉树
数据结构·c++·算法·题解·洛谷·树形结构·gesp六级
smj2302_796826521 小时前
解决leetcode第3948题字典序最大的MEX数组
python·算法·leetcode
周末也要写八哥2 小时前
浅谈:C++中cpp 14 ~ cpp 17
开发语言·c++·算法
c238562 小时前
map和set
数据结构·c++
许彰午2 小时前
13_HashMap底层原理详解
算法·哈希算法
GIOTTO情2 小时前
基于 NLP 情感加权算法的智能舆情处置系统架构与落地实现
人工智能·算法·自然语言处理
无风听海2 小时前
PKCE 的 S256 算法深度剖析:从协议设计到密码学原理
javascript·网络·算法·密码学
凌波粒2 小时前
LeetCode--530.二叉搜索树的最小绝对差(二叉树)
算法·leetcode·职场和发展
sali-tec3 小时前
C# 基于OpenCv的视觉工作流-章82-毛刺检测
图像处理·人工智能·opencv·算法·计算机视觉