题解 | #接雨水问题#

接雨水问题

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

```package main

/**
 * max water
 * @param arr int整型一维数组 the array
 * @return long长整型
*/
func maxWater( arr []int ) int64 {
    // write code here
    n := len(arr)
    if n == 0 {return 0}
    leftmax := make([]int, n)
    leftmax[0] = arr[0]
    for i := 1; i < n; i++ {
        leftmax[i] = max(leftmax[i-1], arr[i])
    }
    
    rightmax := make([]int, n)
    rightmax[n-1] = arr[n-1]
    for i := n-2; i >= 0; i-- {
        rightmax[i] = max(rightmax[i+1], arr[i])
    }
    ans := 0
    for i, h := range arr {
        ans += min(leftmax[i], rightmax[i]) - h
    }
    return int64(ans)
}
func min(a, b int) int{
    if a < b  {
        return a
    }
    return b
}
func max(a, b int) int {
    if a < b {
        return b
    }
    return a
}
全部评论

相关推荐

GGrain:没事,本硕985也不发面试笔试😖
点赞 评论 收藏
分享
09-26 17:07
门头沟学院 Java
点赞 评论 收藏
分享
本人末二本,C++后端选手,目前手里两个意向:美团移动端和字节客户端。但全网都是劝退客户端的,不知道要不要接。但现在转java已经没办法赶上秋招了,很焦虑,不知道要不要转java备战春招,求各位大佬给给建议。
小破站_程序员YT:作为一个末二本,c++后端选手,手握两个大厂意向,你竟然还在犹豫要不要接,还要去转java? 真不知道你怎么想的。不知道有多少人羡慕你还来不及。
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务