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
}
相关推荐
简单点了8 小时前
go前后端项目的启动 、打包和部署
开发语言·后端·golang
九江Mgx10 小时前
用 Go 手搓一个 NTP 服务:从“时间混乱“到“精准同步“的奇幻之旅
golang·ntp
im_AMBER10 小时前
Leetcode 33
算法·leetcode·职场和发展
坚持编程的菜鸟13 小时前
LeetCode每日一题——二进制求和
c语言·算法·leetcode
爱coding的橙子16 小时前
每日算法刷题Day77:10.22:leetcode 二叉树bfs18道题,用时3h
算法·leetcode·职场和发展
Swift社区16 小时前
LeetCode 404:左叶子之和(Sum of Left Leaves)
算法·leetcode·职场和发展
一匹电信狗17 小时前
【C++】手搓AVL树
服务器·c++·算法·leetcode·小程序·stl·visual studio
脚踏实地的大梦想家17 小时前
【Go】P11 掌握 Go 语言函数(二):进阶玩转高阶函数、闭包与 Defer/Panic/Recover
开发语言·后端·golang
野蛮人6号19 小时前
力扣热题100道之73矩阵置零
算法·leetcode·矩阵
野蛮人6号19 小时前
力扣热题100道之238除自身以外数组的乘积
算法·leetcode·职场和发展