【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;
    }
}
相关推荐
字节源流4 小时前
关于maven的依赖下不下来的问题
java·maven
勇闯逆流河4 小时前
【数据结构】堆
c语言·数据结构·算法
pjx9875 小时前
服务间的“握手”:OpenFeign声明式调用与客户端负载均衡
java·运维·spring·负载均衡
prinrf('千寻)5 小时前
MyBatis-Plus 的 updateById 方法不更新 null 值属性的问题
java·开发语言·mybatis
pystraf5 小时前
LG P9844 [ICPC 2021 Nanjing R] Paimon Segment Tree Solution
数据结构·c++·算法·线段树·洛谷
老华带你飞5 小时前
实习记录小程序|基于SSM+Vue的实习记录小程序设计与实现(源码+数据库+文档)
java·数据库·spring boot·小程序·论文·毕设·实习记录小程序
在未来等你6 小时前
互联网大厂Java求职面试:AI与大模型应用集成及云原生挑战
java·微服务·ai·kubernetes·大模型·embedding·spring ai
飞川撸码6 小时前
【LeetCode 热题100】739:每日温度(详细解析)(Go语言版)
算法·leetcode·golang
源码技术栈6 小时前
SaaS基于云计算、大数据的Java云HIS平台信息化系统源码
java·大数据·云计算·云his·his系统·云医院·区域his
编程、小哥哥6 小时前
互联网大厂Java面试:从Spring Boot到微服务架构的技术深挖
java·spring boot·redis·微服务·prometheus·面试技巧