Golang | Leetcode Golang题解之第42题接雨水

题目:

题解:

Go 复制代码
func trap(height []int) (ans int) {
    n := len(height)
    if n == 0 {
        return
    }

    leftMax := make([]int, n)
    leftMax[0] = height[0]
    for i := 1; i < n; i++ {
        leftMax[i] = max(leftMax[i-1], height[i])
    }

    rightMax := make([]int, n)
    rightMax[n-1] = height[n-1]
    for i := n - 2; i >= 0; i-- {
        rightMax[i] = max(rightMax[i+1], height[i])
    }

    for i, h := range height {
        ans += min(leftMax[i], rightMax[i]) - h
    }
    return
}

func min(a, b int) int {
    if a < b {
        return a
    }
    return b
}

func max(a, b int) int {
    if a > b {
        return a
    }
    return b
}
相关推荐
liurunlin88819 分钟前
Go环境搭建(vscode调试)
开发语言·vscode·golang
memcpy039 分钟前
LeetCode 1456. 定长子串中元音的最大数目【定长滑窗模板题】中等
算法·leetcode·职场和发展
玛丽莲茼蒿1 小时前
LeetCode hot100【相交链表】【简单】
算法·leetcode·职场和发展
wen__xvn1 小时前
力扣模拟题刷题
算法·leetcode
不要秃头的小孩1 小时前
力扣刷题——111.二叉树的最小深度
数据结构·python·算法·leetcode
We་ct2 小时前
LeetCode 35. 搜索插入位置:二分查找的经典应用
前端·算法·leetcode·typescript·个人开发
Navigator_Z2 小时前
LeetCode //C - 990. Satisfiability of Equality Equations
c语言·算法·leetcode
添尹3 小时前
Go语言基础之流程控制
golang
添尹3 小时前
Go语言基础之基本数据类型
开发语言·后端·golang
lightqjx4 小时前
【算法】前缀和
c++·算法·leetcode·前缀和