接雨水(给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。)

题目;

接雨水

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。

示例:

接雨水(给定 n 个非负整数表示每个宽度为 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 rain = 0;
    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]) {
            rain = rain + (min - height[i]);
        }
    }
    return rain;
}

上一篇:[Leetcode 42]雨天积水面积Trapping Rain Water


下一篇:机械祭天乏力无边:C++ Primer习题3.2:编写一段程序从标准输入中一次读入一整行,然后修改该程序使其一次读入一个词。