给定?n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。
上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。?感谢 Marcos 贡献此图。
示例:
输入: [0,1,0,2,1,0,1,3,2,1,2,1]
输出: 6
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/trapping-rain-water
class Solution {
public int trap(int[] height) {
if(height==null||height.length==0){
return 0;
}
int len=height.length;
int[] lMax=new int[len];
int[] rMax=new int[len];
lMax[0]=0;
rMax[len-1]=0;
for(int i=1;i<len;++i){
lMax[i]=Math.max(lMax[i-1],height[i-1]);
}
for(int i=len-2;i>=0;--i){
rMax[i]=Math.max(rMax[i+1],height[i+1]);
}
int ans=0;
for(int i=0;i<len;++i){
int dif=Math.min(lMax[i],rMax[i])-height[i];
ans=dif>0?ans+dif:ans;
}
return ans;
}
}
class Solution {
public int trap(int[] height) {
if(height==null||height.length==0){
return 0;
}
int len=height.length;
int lMax=0;
int rMax=0;
int l=0;
int r=len-1;
int ans=0;
while(l<r){
if(height[l]<=height[r]){
if(height[l]>=lMax){
lMax=height[l];
}
else{
ans+=lMax-height[l];
}
++l;
}
else{
if(height[r]>=rMax){
rMax=height[r];
}
else{
ans+=rMax-height[r];
}
--r;
}
}
return ans;
}
}
原文:https://www.cnblogs.com/coding-gaga/p/11333317.html