代码随想录算法训练营 | 单调栈

739. 每日温度 - 力扣(LeetCode)//中等。之前哪道题讲过单调栈来着。忘记了。反正这题懂单调栈就能a,没什么难度

复制代码
class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        vector<int> answer(temperatures.size(),0);
        vector<int> st;
        st.push_back(0);
        for(int i=1;i<temperatures.size();i++){
            while(!st.empty()&&temperatures[i]>temperatures[st.back()]){
                answer[st.back()]=i-st.back();
                st.pop_back();
            }
            st.push_back(i);
        }
        return answer;
    }
};

496. 下一个更大元素 I - 力扣(LeetCode)//简单。如果要用单调栈的话,实现起来并不算特别简单。。

复制代码
class Solution {
public:
    vector<int> nextGreaterElement(vector<int>& nums1, vector<int>& nums2) {
        vector<int> ans(nums1.size(),-1);
        unordered_map<int,int> map;
        stack<int> st;
        for(int i=0;i<nums1.size();i++){
            map[nums1[i]]=i;
        }
        st.push(nums2[0]);
        for(int i=1;i<nums2.size();i++){    
            while(!st.empty()&&nums2[i]>st.top()){
                if(map.find(st.top())!=map.end()){
                    ans[map[st.top()]]=nums2[i];
                }
                st.pop();
            }
            st.push(nums2[i]);      
        }
        return ans; 
    }
};

503. 下一个更大元素 II - 力扣(LeetCode)//中等。懒得想。直接跑两次,然后用余数区分一下即可。写完一看思路差不多。

复制代码
class Solution {
public:
    vector<int> nextGreaterElements(vector<int>& nums) {
        vector<int> ans(nums.size(),-1);int i=1;
        stack<int> st;
        st.push(0);
        while(i<2*nums.size()){
            while(!st.empty()&&nums[i%nums.size()]>nums[st.top()]&&ans[st.top()]==-1){
                ans[st.top()]=nums[i%nums.size()];
                st.pop();
            }
            if(ans[i%nums.size()]==-1)
            st.push(i%nums.size());
            i++;
        }
        return ans;
    }
};

42. 接雨水 - 力扣(LeetCode)//困难。难点在于知道单调栈之后如何妥当的计算面积

复制代码
class Solution {
public:
    int trap(vector<int>& height) {
        int count=0;
        vector<int> st;
        st.reserve(height.size());
        st.push_back(0);
        for(int i=1;i<height.size();i++){
            while(!st.empty()&&height[st.back()]<height[i]){//满足条件说明出现凹槽
                int mintemp=st.back();
                st.pop_back();
                if(!st.empty()){
                    count+=((min(height[st.back()],height[i])-height[mintemp])*(i-st.back()-1));
                }
            }
            st.push_back(i);
        }
        return count;
    }
};

84. 柱状图中最大的矩形 - 力扣(LeetCode)//困难。虽然和接雨水有异曲同工之妙,但是边界处理比雨水要复杂一点。

复制代码
class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        heights.insert(heights.begin(),0);
        heights.push_back(0);
        int count=0;
        stack<int> st;
        st.push(0);
        for(int i=1;i<heights.size();i++){
            while(!st.empty()&&heights[st.top()]>heights[i]){
                int temp=st.top();
                st.pop();
                if(!st.empty())
                count=max(count,(i-st.top()-1)*heights[temp]);
            }
            st.push(i);
        } 
        return count;   
    }
};
相关推荐
写代码的小球2 小时前
求模运算符c
算法
大千AI助手5 小时前
DTW模版匹配:弹性对齐的时间序列相似度度量算法
人工智能·算法·机器学习·数据挖掘·模版匹配·dtw模版匹配
YuTaoShao7 小时前
【LeetCode 热题 100】48. 旋转图像——转置+水平翻转
java·算法·leetcode·职场和发展
生态遥感监测笔记7 小时前
GEE利用已有土地利用数据选取样本点并进行分类
人工智能·算法·机器学习·分类·数据挖掘
Tony沈哲7 小时前
macOS 上为 Compose Desktop 构建跨架构图像处理 dylib:OpenCV + libraw + libheif 实践指南
opencv·算法
刘海东刘海东8 小时前
结构型智能科技的关键可行性——信息型智能向结构型智能的转变(修改提纲)
人工智能·算法·机器学习
pumpkin845148 小时前
Rust 调用 C 函数的 FFI
c语言·算法·rust
挺菜的9 小时前
【算法刷题记录(简单题)003】统计大写字母个数(java代码实现)
java·数据结构·算法
mit6.8249 小时前
7.6 优先队列| dijkstra | hash | rust
算法