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;
    }
};
相关推荐
梵刹古音31 分钟前
【C语言】 字符数组相关库函数
c语言·开发语言·算法
wfeqhfxz25887827 小时前
YOLO13-C3k2-GhostDynamicConv烟雾检测算法实现与优化
人工智能·算法·计算机视觉
芝士爱知识a7 小时前
2026年AI面试软件推荐
人工智能·面试·职场和发展·大模型·ai教育·考公·智蛙面试
Aaron15888 小时前
基于RFSOC的数字射频存储技术应用分析
c语言·人工智能·驱动开发·算法·fpga开发·硬件工程·信号处理
石去皿9 小时前
大模型面试通关指南:28道高频考题深度解析与实战要点
人工智能·python·面试·职场和发展
程序员辣条9 小时前
AI产品经理:2024年职场发展的新机遇
人工智能·学习·职场和发展·产品经理·大模型学习·大模型入门·大模型教程
AI大模型测试9 小时前
大龄程序员想转行到AI大模型,好转吗?
人工智能·深度学习·机器学习·ai·语言模型·职场和发展·大模型
美团程序员9 小时前
80道经典常见测试面试题
软件测试·面试·职场和发展·软件测试面试
sunguang20189 小时前
“懂不懂管理,一看便知”:做管理就是3件事,抓大、放小、管细做管理,其实就是要做好三件事:抓大、放小、管细。
经验分享·职场和发展
ProcessOn官方账号9 小时前
程序员如何与同龄人拉开差距?这5张让你快速提升认知,打开格局!
深度学习·职场和发展·学习方法