Ai
1 Star 0 Fork 0

wu-xjg/LeetCode

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
Code42.java 1.45 KB
一键复制 编辑 原始数据 按行查看 历史
wu-xjg 提交于 2025-02-17 17:06 +08:00 . day01
package Code;
public class Code42 {
static int water(int[] height){
int n = height.length;
int res = 0;
int[] leftArr = new int[n];
int[] rightArr = new int[n];
leftArr[0] = height[0];
for(int i = 1; i< n; i++){
leftArr[i] = Math.max(leftArr[i-1], height[i]);
}
rightArr[n-1] = height[n-1];
for(int i = n-2; i>= 0; i--){
rightArr[i] = Math.max(rightArr[i+1], height[i]);
}
for(int i = 0; i< n; i++){
res += Math.min(leftArr[i], rightArr[i]) - height[i];
}
return res;
}
static int water1(int[] height){
int n = height.length;
int res = 0;
int l = 0, r = n-1;
int leftMax = 0, rightMax = 0;
while(l < r){
if(height[l] < height[r]){
if(height[l] > leftMax){
leftMax = height[l];
}else {
res += leftMax - height[l];
}
l++;
}else{
if(height[r] > rightMax){
rightMax = height[r];
}else{
res += rightMax - height[r];
}
r--;
}
}
return res;
}
public static void main(String[] args) {
System.out.println(water(new int[]{0,1,0,2,1,0,1,3,2,1,2,1}));
System.out.println(water1(new int[]{0,1,0,2,1,0,1,3,2,1,2,1}));
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/wu-xjg/leet-code.git
git@gitee.com:wu-xjg/leet-code.git
wu-xjg
leet-code
LeetCode
master

搜索帮助