博客
关于我
数据结构与算法(三) 03-平衡二叉树及二叉树的经典题型
阅读量:674 次
发布时间:2019-03-15

本文共 855 字,大约阅读时间需要 2 分钟。

判断平衡二叉树的方法是通过递归检查左右子树的深度差是否在1以内。

方法思路

为了判断一棵二叉树是否是平衡二叉树,我们可以使用递归的方法来检查每个子树的深度差是否在1以内。具体步骤如下:

  • 递归判断左右子树深度:对于每个节点,先递归判断左子树和右子树的深度。
  • 比较深度差:检查左子树和右子树的深度差是否超过1。如果超过,返回-1表示不平衡。
  • 返回最大深度加1:如果左右子树都平衡,则返回左右子树深度较大的那个加1作为当前节点的深度。
  • 代码实现

    function IsBalanced_Solution(pRoot) {    function balanced(node) {        if (!node) {            return 0;        }        const left = balanced(node.left);        const right = balanced(node.right);        if (left === -1 || right === -1 || Math.abs(left - right) > 1) {            return -1;        }        return Math.max(left, right) + 1;    }    return balanced(pRoot) !== -1;}

    解释

    • 函数IsBalanced_Solution:这个函数接收二叉树的根节点作为输入,调用balanced函数进行判断,并返回结果。
    • 函数balanced:这是一个递归函数,用于判断一棵二叉树是否是平衡二叉树。
      • 当遇到空树时,返回0,表示深度为0。
      • 递归检查左子树和右子树的深度。
      • 比较左子树和右子树的深度,如果任意一个返回-1,或者深度差超过1,返回-1。
      • 如果左右子树都平衡,返回最大深度加1作为当前节点的深度。

    这种方法确保了每个节点都被检查,并且时间复杂度为O(n),其中n是二叉树的节点数。

    转载地址:http://wlqmz.baihongyu.com/

    你可能感兴趣的文章
    Phoenix简介_安装部署_以及连接使用---大数据之Hbase工作笔记0035
    查看>>
    phoenix连接hbase报错Can not resolve hadoop120, please check your network_记录026---大数据工作笔记0187
    查看>>
    Photoshop工作笔记001---Photoshop常用快捷键总结
    查看>>
    Reids配置文件redis.conf中文详解
    查看>>
    PHP
    查看>>
    Regular Expression Notes
    查看>>
    PHP $FILES error码对应错误信息
    查看>>
    PHP $_FILES函数详解
    查看>>
    php & 和 & (主要是url 问题)
    查看>>
    php -- 魔术方法 之 判断属性是否存在或为空:__isset()
    查看>>
    php -- 魔术方法 之 获取属性:__get()
    查看>>
    php -树-二叉树的实现
    查看>>
    PHP -算法-二路归并
    查看>>
    php 2条不一样 的json数据 怎么放在一个json里面_如果你是PHP开发者,请务必了解一下Composer...
    查看>>
    php 360 不记住密码,JavaScript_多种方法实现360浏览器下禁止自动填写用户名密码,目前开发一个项目遇到一个很 - phpStudy...
    查看>>
    regExp的match、exec、test区别
    查看>>
    php aes sha1解密,PHP AES加密/解密
    查看>>
    php csv 导出
    查看>>
    PHP imap 远程命令执行漏洞复现(CVE-2018-19518)
    查看>>
    php include和require
    查看>>