博客
关于我
数据结构与算法(三) 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/

    你可能感兴趣的文章
    Node响应中文时解决乱码问题
    查看>>
    node基础(二)_模块以及处理乱码问题
    查看>>
    node安装及配置之windows版
    查看>>
    Node实现小爬虫
    查看>>
    Node提示:error code Z_BUF_ERROR,error error -5,error zlib:unexpected end of file
    查看>>
    Node提示:npm does not support Node.js v12.16.3
    查看>>
    Node搭建静态资源服务器时后缀名与响应头映射关系的Json文件
    查看>>
    Node服务在断开SSH后停止运行解决方案(创建守护进程)
    查看>>
    node模块化
    查看>>
    node环境下使用import引入外部文件出错
    查看>>
    node编译程序内存溢出
    查看>>
    Node读取并输出txt文件内容
    查看>>
    node防xss攻击插件
    查看>>
    noi 1996 登山
    查看>>
    noi 7827 质数的和与积
    查看>>
    NOIp2005 过河
    查看>>
    NOIP2011T1 数字反转
    查看>>
    NOIP2014 提高组 Day2——寻找道路
    查看>>
    NOIp模拟赛二十九
    查看>>
    Nokia5233手机和我装的几个symbian V5手机软件
    查看>>