day04(11.2)——leetcode面试经典150

42. 接雨水

这题我一开始想的是从左到右遍历除了头尾的所有列,在第i列的时候,先从左边找到最高的一列,再从右边找到最高的一列,再来判断是左边的最高列更小还是右边的最高列更小,最后如果更小的最高列如果大于当前i的高度,则sum要加上他们之间的差值。。。但是这样就寄了,超时了,所以我看题解了哈哈哈哈,用了双指针的方法:

左边一个left指向最左边,右边一个right指向最右边,左边永远小于右边进行循环判断,判断一下当前左右两边的指针是否大于左右两边各自的高度最大值,如果大于,那就更新,如果小于,那就不用管了,然后再进行判断比较左边的最大值大,还是右边的最大值大,如果左边的最大值大,说明左边的墙更高,右边的墙更矮,右边的点只需要低于右边的最大值就能产生积水,所以先判断一下当前右边的点是否小于当前右边的最大值,如果小于,则他们的差值累加到积水的总值上,右边再往中间走一步,左边亦是如此.....

42. 接雨水

题目:

题解:

java 复制代码
class Solution {
    public int trap(int[] height) {
        // 左右指针指向索引
        int left = 0;
        int right = height.length-1;
        // 计算左边碰到最高的柱子的长度
        int leftMax = 0;
        //计算右边碰到最高的柱子的长度
        int rightMax = 0;
        // 用来统计积水
        int sum = 0;
        while(left < right) {
            // 更新当前左边的最高柱子的长度
            if(height[left] > leftMax) {
                leftMax = height[left];
            }
            // 更新当前右边的最高柱子的长度
            if(height[right] > rightMax) {
                rightMax = height[right];
            }
            //如果当前左边的最高柱子短于当前右边柱子的长度
            //此时说明左边如果有短于这个左边最长柱子长度的柱子,
            //那么就一定是积水,所以从左边开始统计积水
            if (leftMax < rightMax ) {
                sum+=(leftMax - height[left]);
                left++;
            }
            //右边更短亦是如此
            else {
                sum+=(rightMax - height[right]);
                right--;
            }
        }
        return sum;
    }
}
相关推荐
超级码力6662 小时前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化
穿条秋裤到处跑2 小时前
每日一道leetcode(2026.04.29):二维网格图中探测环
算法·leetcode·职场和发展
Merlos_wind2 小时前
HashMap详解
算法·哈希算法·散列表
汉克老师3 小时前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
Yzzz-F5 小时前
Problem - 2205D - Codeforces
算法
智者知已应修善业6 小时前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn6 小时前
Java Set集合相关知识点
java·开发语言·算法
生成论实验室7 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星7 小时前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
科研前沿8 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算