当前位置: 首页 > 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/news/304444.html

相关文章:

  • 【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详解
  • 分享六款小众宝藏软件,建议收藏!
  • golang os.Eixt的介绍和使用
  • 【C++】vector常见用法
  • 数字化大屏解决方案 - GoView
  • 如何通俗易懂的解释TON的智能合约
  • DolphinScheduler应用实战笔记
  • ROS2 Control controller_interface说明
  • 论文阅读笔记: DINOv2: Learning Robust Visual Features without Supervision
  • LOAM学习
  • camouflaged object detection中的decoder最核心的作用
  • Amazon EC2:灵活、可扩展的云计算解决方案