leetcode 42.接雨水

问题1:怎么算接水量

  • 总的接水量=第一列接水量+第二列接水量+第三列接水量+...+最后一列接水量

问题2:当前列的接水量怎么计算

  • 当前的接水量=min(当前列左边最高的墙x1,当前列右边最高的墙x3)- 当前列x2的高度

问题2图解:

方法:预处理每一列左边最高的墙+预处理每一列右边最高的墙(记录下标)

cpp 复制代码
class Solution 
{
public:
    int trap(vector<int>& height) 
    {
        int n=height.size();
        int leftMax[n],rightMax[n];
        memset(leftMax,0,sizeof(int)*n);
        memset(rightMax,0,sizeof(int)*n);
        int lmax=height[0]; 
        int rmax=height[n-1];
        for(int i=1;i<n;i++)   //预处理,没自己写看起来有点小难懂,自己模拟写一个即可
        {
            leftMax[i]=lmax;
            lmax=max(lmax,height[i]);
            rightMax[n-i-1]=rmax;
            rmax=max(rmax,height[n-i-1]);
        }
        int sum=0;
        for(int i=1;i<n-1;i++)  //一列一列的算,为什么不算第一列和最后一列,因为最左边和最右边就是边界,相当于最后的墙
        {
            if(min(leftMax[i],rightMax[i])<=height[i])continue;
            sum+=min(leftMax[i],rightMax[i])-height[i];
        }
        return sum;
    }
};
相关推荐
QiLinkOS38 分钟前
第三视觉理解徐玉生与他的商业活动(28)
大数据·c++·人工智能·算法·开源协议
码云数智-大飞1 小时前
从 OC 平滑迁移 Swift 完整方案
职场和发展·蓝桥杯
wabs6661 小时前
关于动态规划【力扣1143.最长公共子序列的思考】
算法·leetcode·动态规划
剑挑星河月2 小时前
54.螺旋矩阵
java·算法·leetcode·矩阵
Robot_Nav2 小时前
MPPI 局部规划器实验设计讲解
人工智能·算法·mppi
mingo_敏2 小时前
Mean-Teacher 均值教师自训练框架详解
算法·均值算法
水木流年追梦3 小时前
agent面试必备31- AI Agent 核心进阶:工具路由(Tool Routing)
数据库·人工智能·oracle·面试·职场和发展·embedding
星空露珠3 小时前
迷你世界UGc3.0脚本Wiki[剧情动画模块管理接口 Timeline]
开发语言·数据结构·算法·游戏·lua
笨笨没好名字3 小时前
Leetcode刷题python3版第一周(下)
linux·算法·leetcode
jinyishu_3 小时前
常见排序算法详解
数据结构·算法·排序算法