题解 | #接雨水问题#

接雨水问题

https://www.nowcoder.com/practice/31c1aed01b394f0b8b7734de0324e00f

直接用快慢指针轻松解决(慢指针i;快指针j),避免用while...
public class Solution {
    public long maxWater(int[] height) {
        if (height.length <= 2)
        return 0;
        int n = height.length,res = 0;
        for (int i = 1; i < n - 1; i++) {
            int l_max = 0, r_max = 0;
            // 找右边最高的bar;
            for (int j = i; j < n; j++)
                r_max = Math.max(r_max, height[j]);
            // 找左边最高的bar;
            for (int j = i; j >= 0; j--)
                l_max = Math.max(l_max, height[j]);
            // (注意:如果自己就是最高的话,
            // l_max / r_max == height[i])
            res += Math.min(l_max, r_max) - height[i];
        }
        return res;
    }

}

全部评论

相关推荐

05-28 23:26
河南大学 Java
双非本,刚学完Redis,项目只有外卖和点评,八股没准备,算法只有lqb省一,感觉敲的项目也是一言难尽没怎么吸收。怎么你们都有实习了
大牛之途:27急个锤子,你投日常实习最好的时间就是9,10月份,那时候暑期实习都结束了,正是缺人的时候。这份日常又能给你的暑期实习增加竞争力,暑期找的好了秋招也不怕了,都是环环相扣的
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务