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;
    }
}
相关推荐
AI科技星5 分钟前
光速飞行器动力学方程的第一性原理推导、验证与范式革命
数据结构·人工智能·线性代数·算法·机器学习·概率论
橘颂TA7 分钟前
【剑斩OFFER】算法的暴力美学——leetCode 946 题:验证栈序列
c++·算法·leetcode·职场和发展·结构与算法
闻缺陷则喜何志丹9 分钟前
【状态机动态规划】3686. 稳定子序列的数量|1969
c++·算法·动态规划·力扣·状态机动态规划
寻星探路20 分钟前
【算法通关】双指针技巧深度解析:从基础到巅峰(Java 最优解)
java·开发语言·人工智能·python·算法·ai·指针
wen__xvn21 分钟前
力扣第 484 场周赛
算法·leetcode·职场和发展
YuTaoShao33 分钟前
【LeetCode 每日一题】865. 具有所有最深节点的最小子树——(解法一)自顶向下
算法·leetcode·职场和发展
寻星探路1 小时前
【算法专题】哈希表:从“两数之和”到“最长连续序列”的深度解析
java·数据结构·人工智能·python·算法·ai·散列表
!停1 小时前
C语言单链表
c语言·数据结构·算法
独自破碎E1 小时前
【队列】求二叉树的层序遍历
leetcode
闻缺陷则喜何志丹1 小时前
【回文 字符串】3677 统计二进制回文数字的数目|2223
c++·算法·字符串·力扣·回文