前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Tree - 110. Balanced Binary Tree

Tree - 110. Balanced Binary Tree

作者头像
ppxai
发布2020-09-23 17:31:06
3630
发布2020-09-23 17:31:06
举报
文章被收录于专栏:皮皮星球

110. Balanced Binary Tree

Given a binary tree, determine if it is height-balanced.

For this problem, a height-balanced binary tree is defined as:

a binary tree in which the depth of the two subtrees of every node never differ by more than 1.

Example 1:

Given the following tree [3,9,20,null,null,15,7]:

代码语言:javascript
复制
    3
   / \
  9  20
    /  \
   15   7

Return true.

Example 2:

Given the following tree [1,2,2,3,3,null,null,4,4]:

代码语言:javascript
复制
       1
      / \
     2   2
    / \
   3   3
  / \
 4   4

Return false.

思路:

题目意思是判断一棵二叉树是否是平衡二叉树。而平衡二叉树的定义是一个二叉树_每个节点 _的左右两个子树的高度差的绝对值不超过1,所以,递归的思想,判断一个树是否为平衡二叉树,就看左右子树的高度差和左右子树是否为平衡二叉树。

代码:

go:

代码语言:javascript
复制
/**

 * Definition for a binary tree node.

 * type TreeNode struct {
 *     Val int
 *     Left *TreeNode
 *     Right *TreeNode
 * }
 */
func isBalanced(root *TreeNode) bool {
    if root == nil {
        return true
    }
    
    left := depth(root.Left)
    right := depth(root.Right)
    
    return abs(left, right) <= 1 && isBalanced(root.Left) && isBalanced(root.Right)
}

func depth(node *TreeNode) int {
    if node == nil {
        return 0
    }
    return max(depth(node.Left), depth(node.Right)) + 1
} 

func abs(i, j int) int {
    if i > j {
        return i - j
    }
    return j - i
}

func max(i, j int) int {
    if i > j {
        return i
    } 
    return j 
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019年08月20日,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

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