代码随想录算法【Day47】

Day49

42. 接雨水

思路

这道题利用单调栈进行横向求解。对于每一个元素,找到它右边第一个比它大的元素和左边第一个比它大(或者与它相等的元素,当然这种情况可以忽略),最后计算雨水的存储量:((左右两边的高度差)减去(中间元素的高度))乘上中间元素的宽度。为什么要乘中间元素的宽度?因为中间元素可能不止一个。

代码

复制代码
class Solution {
public:
    int trap(vector<int>& height) {
        // if(height.size() <= 2) return 0;   //加不加都可以,最好加上
        stack<int> st;
        st.push(0);
        int sum;
        for(int i = 1; i < height.size(); i++){ //直接从第二个元素开始遍历
            if(height[i] < height[st.top()]) st.push(i);
            else if(height[i] == height[st.top()]){
                st.pop();
                st.push(i);
            }
            else{
                while(!st.empty() && height[i] > height[st.top()]){
                    int mid = st.top();
                    st.pop();
                    if(!st.empty()){   //如果这里是true,会发生什么?
                        int h = min(height[st.top()], height[i]) - height[mid];
                        int w = i - st.top() - 1;
                        sum += h * w;
                    }
                }
                st.push(i);
            }
        }
        return sum;
    }
};

等等

相关推荐
CoovallyAIHub1 分钟前
从电影特效到体育科学,运动追踪只能靠“人眼”吗?
深度学习·算法·计算机视觉
风筝在晴天搁浅1 分钟前
hot100 48.旋转图像
算法
TechNomad18 分钟前
排序算法:希尔排序算法
数据结构·算法·排序算法
热爱生活的猴子18 分钟前
算法中DFS & BFS 核心学习笔记
算法·深度优先·宽度优先
im_AMBER19 分钟前
Leetcode 83 使数组平衡的最少移除数目中等相关标签 | 尽可能使字符串相等
数据结构·c++·笔记·学习·算法·leetcode
TechNomad21 分钟前
排序算法:快速排序算法
算法·排序算法
xu_yule21 分钟前
算法基础(图论)—拓扑排序
c++·算法·动态规划·图论·拓扑排序·aov网
mu_guang_22 分钟前
算法图解1-算法简介
算法·cpu·计算机体系结构
CoovallyAIHub23 分钟前
超越CUDA围墙:国产GPU在架构、工艺与软件栈的“三维替代”挑战
深度学习·算法·计算机视觉
不穿格子的程序员23 分钟前
从零开始写算法——二叉树篇2:二叉树的最大深度 + 翻转二叉树
算法·二叉树·深度优先