Leetcode42. 接雨水 (困难)

该博客介绍了一种解决计算机科学中经典问题——计算雨水在一组柱子上堆积的体积的方法。通过预处理找出每个位置左右两侧的最大高度,然后利用短板原则计算每个位置能接的雨水量。算法实现了时间复杂度为O(N)和空间复杂度为O(N)的优化,避免了超时的情况。
摘要由CSDN通过智能技术生成

题意:
给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。
思路:
我们把每个下标对应的位置当成独立的个体来看,对于当前位置能接水的体积,根据短板原理,是由左右两边最矮的那个来决定的,因此对于每个位置能接水的体积,是他左边最高的柱子与右边最高的柱子两者取小。但是两层循环是超时的,我们可以预处理,提前处理出左右两边到当前位置的最大值。

public int trap(int[] height) {
        int maxn=30005;
        int maxl[]=new int[maxn],maxr[]=new int[maxn];
        Arrays.fill(maxl,0);
        Arrays.fill(maxr,0);
        for(int i=1;i<height.length;i++){
            maxl[i]=Math.max(maxl[i-1],height[i-1]);
        }
        for(int i=height.length-2;i>=0;i--){
            maxr[i]=Math.max(maxr[i+1],height[i+1]);
        }
        int ans=0;
        for(int i=0;i<height.length;i++){
            ans+=Math.max(Math.min(maxl[i],maxr[i])-height[i],0);
        }
        return ans;
    }

时间复杂度O(N)
空间复杂度O(N)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值