当前位置:网站首页>28.接雨水
28.接雨水
2022-07-21 18:06:00 【小开心】
42. 接雨水
给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。
示例 1:
输入:height = [0,1,0,2,1,0,1,3,2,1,2,1]
输出:6
解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。
示例 2:
输入:height = [4,2,0,3,2,5]
输出:9
public int trap(int[] height) {
int sum = 0;
//最两端的列不用考虑,因为一定不会有水。所以下标从 1 到 length - 2
for (int i = 1; i < height.length - 1; i++) {
int max_left = 0;
//找出左边最高
for (int j = i - 1; j >= 0; j--) {
if (height[j] > max_left) {
max_left = height[j];
}
}
int max_right = 0;
//找出右边最高
for (int j = i + 1; j < height.length; j++) {
if (height[j] > max_right) {
max_right = height[j];
}
}
//找出两端较小的
int min = Math.min(max_left, max_right);
//只有较小的一段大于当前列的高度才会有水,其他情况不会有水
if (min > height[i]) {
sum = sum + (min - height[i]);
}
}
return sum;
}
单调栈
public int trap6(int[] height) {
int sum = 0;
Stack<Integer> stack = new Stack<>();
int current = 0;
while (current < height.length) {
//如果栈不空并且当前指向的高度大于栈顶高度就一直循环
while (!stack.empty() && height[current] > height[stack.peek()]) {
int h = height[stack.peek()]; //取出要出栈的元素
stack.pop(); //出栈
if (stack.empty()) {
// 栈空就出去
break;
}
int distance = current - stack.peek() - 1; //两堵墙之前的距离。
int min = Math.min(height[stack.peek()], height[current]);
sum = sum + distance * (min - h);
}
stack.push(current); //当前指向的墙入栈
current++; //指针后移
}
return sum;
}
边栏推荐
猜你喜欢
贪吃蛇
EAS web BIM start access prompt 500 error
When packaged in the form of build patches, the client cannot load metadata.
MySQL installation configuration -version 8.0 -windows
Gan objective function understanding
Byte stream
Bigkey and hotspot key of redis principle
EAS Web 页面预览报错界面显示空白
Development environment EAS login license modification
win10 以微软账户登录 默认打开所有程序以管理员权限打开:2020-12-14
随机推荐
uni拦截器
High frequency leetcode deep search part: 695 Maximum area of the island
core technology
高频leetcode深搜部分:617. 合并二叉树
微信小程序width100%时padding或者border后导致超出边距的解决方案
simplest-i18n
高频leetcode深搜部分:112. 路径总和
小程序输出console
关于线程 thread (4)线程的交互
Gluttonous snake
Date function of Oracle function Encyclopedia
Activity启动(launchActivity/startActivity)_(1)_流程图之WMS
Permission
ConstraintLayout从0到0.n学习
PyCharm 安装适用指南
数组的复制和数组地址值的复制
生物化学复习VI·生物氧化
排序方法--冒泡排序(使用数组实现一串数字的从大到小或从小到大排序)
EAS BOS 自定义导出(含Excel样式设置、多页签导出、导出文件目录校验及备份)
Vector Foundation