当前位置: 首页 > article >正文

【数据结构和算法实践-树-LeetCode110-平衡二叉树】

数据结构和算法实践-树-LeetCode110-平衡二叉树

    • 题目
    • My Thought
    • 代码示例
      • JAVA-8

题目

给定一个二叉树,判断它是否是
平衡二叉树

输入:root = [3,9,20,null,null,15,7]
输出:true

My Thought

判断平衡二叉树的条件是树的左右高度相差为1
一、利用递归去遍历
1、边界为节点为null,树高为0;
2、树高的递增规则为,根的左节点和右节点比较值+1
二、为了方便信息传递,需要设置一个实体存储高度和是否平衡

代码示例

JAVA-8

    public boolean isBalanced(TreeNode root) {
        return process(root).isBalanced;
    }

    private NodeInfo process(TreeNode root) {
        if (root == null) {
            return new NodeInfo(0, true);
        }
        NodeInfo leftNode = process(root.left);
        NodeInfo rightNode = process(root.right);
        int height = Math.max(leftNode.height, rightNode.height) + 1;
        boolean isBalanced = leftNode.isBalanced && rightNode.isBalanced && Math.abs(leftNode.height - rightNode.height) < 2;
        return new NodeInfo(height, isBalanced);
    }

http://www.kler.cn/a/304444.html

相关文章:

  • ubuntu22.04安装PaddleX3
  • 2、光同步数字传送网的特点
  • 重温设计模式--组合模式
  • docker安装nginx,docker部署vue前端,以及docker部署java的jar部署
  • 目标检测-R-CNN
  • 3D架构图软件 iCraft Editor 正式发布 @icraftplayer-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
  • 【STM32 HAL库】IIC通信与CubeMX配置
  • InfiniBand (IB) 和 RDMA over Converged Ethernet (RoCE)
  • S32G EB tresos AutoCore下载和激活方法
  • GSEP 7级T2真题 [202312]纸牌游戏
  • [pytorch] 训练节省显存的技巧
  • Kizuna AI——AI驱动虚拟偶像,AI分析观众的反应和互动,应用娱乐、直播和广告行业
  • Linux(RedHat或CentOS)下如何开启telnet服务
  • 【时时三省】(C语言基础)指针进阶 例题7
  • SQLITE3数据库实现信息的增删改查
  • ensp—路由过滤、路由引入、路由策略
  • 【基础知识复习 - 随机练习题】
  • 1935. 公交换乘(transfer)
  • 常用环境部署(二十)——docker部署OpenProject
  • 基于华为云服务器的网页部署
  • 【Android】使用和风天气API获取天气数据吧!(天气预报系列之一)
  • ARCGIS PRO DSK MapTool
  • 使用Azure Devops Pipeline将Docker应用部署到你的Raspberry Pi上
  • 【Hadoop|MapReduce篇】Hadoop序列化概述
  • LabVIEW FIFO详解
  • 分享六款小众宝藏软件,建议收藏!