题解 | #接雨水问题#

接雨水问题

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
}
全部评论

相关推荐

09-27 10:54
重庆大学 C++
人已微死:致敬传奇耐测王。
投递小米集团等公司10个岗位
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务