Golang | Leetcode Golang题解之第563题二叉树的坡度

题目:

题解:

Go 复制代码
func findTilt(root *TreeNode) (ans int) {
    var dfs func(*TreeNode) int
    dfs = func(node *TreeNode) int {
        if node == nil {
            return 0
        }
        sumLeft := dfs(node.Left)
        sumRight := dfs(node.Right)
        ans += abs(sumLeft - sumRight)
        return sumLeft + sumRight + node.Val
    }
    dfs(root)
    return
}

func abs(x int) int {
    if x < 0 {
        return -x
    }
    return x
}
相关推荐
样例过了就是过了11 分钟前
LeetCode热题100 和为 K 的子数组
数据结构·算法·leetcode
Frostnova丶37 分钟前
LeetCode 67. 二进制求和
算法·leetcode
昌兵鼠鼠1 小时前
LeetCode Hot100 哈希
学习·算法·leetcode·哈希算法
脏脏a1 小时前
【优选算法・双指针】以 O (n) 复杂度重构数组操作:从暴力遍历到线性高效的范式跃迁
算法·leetcode·双指针·牛客·优选算法
kamisama_zhu1 小时前
LeetCode 热题100快速通关指南(附模板) (优化完整版,真人心得版,持续更新)
算法·leetcode·职场和发展
蒟蒻小袁3 小时前
力扣hot-100(一刷自用版)
leetcode·哈希算法·散列表
我不是8神3 小时前
go-zero微服务框架总结
开发语言·微服务·golang
踩坑记录3 小时前
leetcode ho100 124. 二叉树中的最大路径和 hard
leetcode
楠秋9204 小时前
代码随想录算法训练营第三十一天|56. 合并区间 、 738.单调递增的数字、968.监控二叉树
数据结构·算法·leetcode·贪心算法
菜鸡儿齐5 小时前
leetcode-和为k的子数组
java·算法·leetcode