前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >检查一个二叉树是否是平衡二叉树leecode111

检查一个二叉树是否是平衡二叉树leecode111

作者头像
用户7962184
发布2020-11-20 15:04:06
3340
发布2020-11-20 15:04:06
举报
文章被收录于专栏:没事多喝水没事多喝水

需要注意的是从底部往上遍历可以减少重复计算。

代码语言:javascript
复制
package main

//Definition for a binary tree node.
type TreeNode struct {
    Val   int
    Left  *TreeNode
    Right *TreeNode
}
/*leecode111
给定一个二叉树,判断它是否是高度平衡的二叉树。

本题中,一棵高度平衡二叉树定义为:

一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过1。*/
func isBalanced(root *TreeNode) bool {
    return getTreeHeight(root) > -1
}

func getTreeHeight(root *TreeNode) int {
    if root == nil {
        return 0
    }
    leftHeight := getTreeHeight(root.Left)
    rightHeight := getTreeHeight(root.Right)
    if leftHeight == -1 || rightHeight == -1 || abs(leftHeight-rightHeight) > 1 {
        return -1
    }
    return max(leftHeight, rightHeight) + 1
}

func max(x, y int) int {
    if x > y {
        return x
    }
    return y
}

func abs(x int) int {
    if x > 0 {
        return x
    }
    return -x
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档