【leetcode hot 100 42】接雨水

错误解法:若height[left]>height[right]则代表有坑

java 复制代码
class Solution {
    public int trap(int[] height) {
        int left = 0;
        int area = 0;
        while(left<height.length-1){
            // 找坑
            int right = left+1;
            while(right<height.length-1 && height[left]>height[right]){
                right++;
            }

            // 计算第i个坑的面积
            int length_i = right-left-1;
            // 取小的那边作为高
            int height_i = height[left]<height[right]?height[left]:height[right];
            int area_i = length_i * height_i;  // 忽略里面存在石头
            // 删除里面的石头
            for(int i=left+1;i<right;i++){
                area_i = area_i - height[i];
            }

            // 加入第i个坑的面积
            area = area + area_i;

            left = right;
        }
        return area;
    }
}

注意:

  • for循环中,条件为i<num.length;但在while循环中,条件为i<num.length-1

错误原因:右边仍满足条件,但没坑

正确解法:预先计算每根柱子的左侧最高柱子(包含该柱子本身)和右侧最高柱子(包含该柱子本身),然后再一次遍历计算每个柱子能接的雨水量。

java 复制代码
class Solution {
    public int trap(int[] height) {
        // 计算每个柱子的左边最大值
        int[] leftMax = new int[height.length]; 
        leftMax[0] = height[0];
        for(int i=1; i<height.length; i++){
            leftMax[i] = Math.max(leftMax[i-1], height[i]);
        }

        // 计算每个柱子的右边最大值
        int[] rightMax = new int[height.length]; 
        rightMax[height.length-1] = height[height.length-1];
        for(int i=height.length-2; i>=0; i--){
            rightMax[i] = Math.max(rightMax[i+1], height[i]);
        } 

        // 计算每个柱子的接水量
        int area = 0;
        for(int i=0; i<height.length; i++){
            area = area + (Math.min(leftMax[i], rightMax[i]) - height[i]);
        }

        return area;
    }
}
相关推荐
康小庄1 分钟前
AQS独占模式——资源获取和释放源码分析
java·开发语言·jvm·spring boot·spring·spring cloud·nio
阿昌喜欢吃黄桃7 分钟前
mac安装mvnd结合idea
java·maven·idea·编译·打包·mvnd·编译打包
wusixuan13100412 分钟前
最大闭合子图学习笔记 / P2805 [NOI2009] 植物大战僵尸
笔记·学习·算法·最大闭合子图
码不停蹄的玄黓37 分钟前
通关JUC:Java并发工具包从入门到精通 | 深度源码解析
java·jvm·spring boot·spring·spring cloud
一只编程菜鸟38 分钟前
Java + easyexcel 新旧数据对比,单元格值标红
java·开发语言
年老体衰按不动键盘1 小时前
idea中导入maven项目的方法
java·maven·intellij-idea
步、步、为营1 小时前
.NET10:asp.net core mini api中的验证
java·asp.net·.net
孟大本事要学习1 小时前
算法第15天:继续二叉树|前序递归+回溯与前序递归的场景总结、最大二叉树、合并二叉树、二叉搜索树中的搜索、验证二叉搜索树
算法
GalaxyPokemon1 小时前
LeetCode - 76. 最小覆盖子串
运维·服务器·数据结构·算法·leetcode
麦兜*1 小时前
【为什么RabbitMQ能够控制事务?控制事务的原理】
java·rabbitmq·java-rabbitmq