110. 平衡二叉树【75】

news2024/11/14 3:09:24

难度等级:容易

上一篇算法:

102. 二叉树的层序遍历【206】

力扣此题地址:

110. 平衡二叉树 - 力扣(Leetcode)

1.题目:110. 平衡二叉树

给定一个二叉树,判断它是否是高度平衡的二叉树。

本题中,一棵高度平衡二叉树定义为:

一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1 。

 2.解题思路:

 自底至顶:思路是对二叉树做先序遍历,从底至顶返回子树的最大高度,若判定某子树不是平衡树则“剪枝”,直接向上返回。

(判断子树是否满足平衡,子树不满足则直接返回,若子树满足,则继续向上比较,用递归的方式依次类推,直到判断根节点的左右子树是否满足平衡。)

算法流程:

递归返回值:

(1)当结点 root 的左/右子树的高度差<2 :则返回以节点root为根节点的子树的最大高度,即结点root的左右子树中最大的高度加1(max(left,right)+1)

(2)当结点 root 的左/右子树的高度差>=2 :则返回 -1,代表此子树不是平衡树

递归终止条件:

(1)当越过叶子结点时,返回高度0;

(代码中:if(root==null)return 0;)root代表当前节点,而不只是根节点,因为是递归,所以一直在调用。

(2)当左(右)子树高度left == -1时,代表此子树的左(右)子树不是平衡树,因此直接返回-1

isBalanced(root):

返回值:若 recur(root)!= 1,则说明此树平衡,返回true,否则返回false

思路参考:

110. 平衡二叉树 - 力扣(Leetcode)

3.代码实现:

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public boolean isBalanced(TreeNode root) {
        return recur(root) != -1;
    }

    private int recur(TreeNode root) {
        if (root == null) return 0;
        int left = recur(root.left);
        if(left == -1) return -1;
        int right = recur(root.right);
        if(right == -1) return -1;
        return Math.abs(left - right) < 2 ? Math.max(left, right) + 1 : -1;
    }
}

平衡二叉树相关知识:

平衡二叉树(AVL树)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/447149.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

realme GT neo5 手机关闭系统更新

realme GT neo5 手机关闭系统更新 前言 realme 手机总是自动系统更新&#xff0c;就很烦&#xff0c;而且今天早上我在付钱的时候&#xff0c;直接就自动关机&#xff0c;更新系统了&#xff0c;让我在那傻等着&#xff0c;我服了 当场我就气晕了 如果要更新&#xff0c;我直…

系统分析师之信息化技术(十一)

目录 一、企业信息化概述 1.1 信息系统的基本概念 1.1.1 什么是信息 1.1.2 什么是信息化 1.1.3 信息系统分类 二、企业信息化规划 2.1 信息化战略体系 2.2 企业战略与信息化战略集成方法 三、信息系统开发方法 3.1 信息系统开发方法 3.2 系统建模 四、信息系统战略…

【机器学习sklearn】第二节:线性回归和线性分类

作者&#x1f575;️‍♂️&#xff1a;让机器理解语言か 专栏&#x1f387;&#xff1a;机器学习sklearn 描述&#x1f3a8;&#xff1a;本专栏主要分享博主学习机器学习的笔记和一些心得体会。 寄语&#x1f493;&#xff1a;&#x1f43e;没有白走的路&#xff0c;每一步都算…

我也曾经因安装库而抓狂,直到我遇到了

入门教程、案例源码、学习资料、读者群 请访问&#xff1a; python666.cn 大家好&#xff0c;欢迎来到 Crossin的编程教室 &#xff01; 几乎所有的 Python 学习者都遇到过“安装”方面的问题。这些安装问题包括 Python 自身环境的安装、第三方模块的安装、不同版本的切换&…

关于二分图

什么是二分图 1. 从离散数学的角度理解&#xff1a; A ---R---> B&#xff0c;B ---R---> A&#xff0c;且A、B自身不存在R关系&#xff0c;那么这种R关系对应的图就是二分图 二分图是一种无向图 2. 从染色问题角度 你会发现&#xff1a; 奇数个结点无法完成染色 &g…

苹果手机相片删除了怎么恢复回来?恢复照片,3分钟搞定!

案例&#xff1a;苹果手机相片删除了还能找到吗&#xff1f; 【友友们&#xff0c;苹果手机照片不小心删除了&#xff0c;有什么方法可以快速恢复吗&#xff1f;】 如果你是苹果手机用户&#xff0c;那么你可能会经常使用手机的相机功能来记录生活中的美好瞬间。然而&#xff…

asp.net+sqlserver+C#网上订餐系统

目 录 第1章.绪论 4 1.1 系统开发背景 4 1.2 开发设计目的和意义 5 1.3 网上订餐系统设计思想 5 1.4可行性分析 6 1.4.1技术可行性分析 7 1.4.2其他可行性分析 7 第2章.需求分析 9 2.1 需求分析 9 2.2建立用例图 11 2.3描述用例图 11 2.3.…

传统机器学习(五)决策树算法(一)

传统机器学习(五)决策树算法(一) 1.1 决策树算法手动实现 ​ 可以参考&#xff1a;机器学习实战&#xff08;二&#xff09;决策树-分类树&#xff08;海洋生物数据集案例&#xff09; 1.2 sklearn决策树参数详解 1.2.1 入参参数详解 class sklearn.tree.DecisionTreeClas…

STM32H7B0VBT6芯片烧写程序踩坑记录

1.新的芯片第一次烧写需要通过ST官方烧录软件CubeProgrammer进行串口烧写。 软件下载: [https://www.stmcu.com.cn/Designresource/detail/software/710763] 或 [https://www.stmcu.com.cn/Designresource/detail/software/710762] 连接串口(A9,A10号引脚),打开文件 BOOT0拉高…

2023年学什么编程语言,最容易找工作?

在众多行业中&#xff0c;程序员属于高薪职业。无论是在国外还是国内&#xff0c;程序员的薪金水平普遍高于其他行业的工作岗位&#xff0c;例如web前端开发、软件工程、游戏开发、APP开发、网络爬虫、网站开发、人工智能开发、网络维护、Java开发、大数据分析、Python开发等工…

【艾特淘】淘宝新灯塔指标已更新,这几点要注意!

2022年新版淘宝新灯塔指标已于2022年8月1日正式生效&#xff0c;新版考核迭代了店铺指标&#xff0c;淘汰了过去考核能力较弱的指标&#xff0c;新增了旺旺满意度、平台求助率等指标&#xff0c;针对商家等级权益也有所调整&#xff0c;很多商家都对这些新的情况比较不了解。为…

JDBC(数据库和Java)

JDBC JDBC&#xff08;Java数据库连接&#xff09;是一种Java API&#xff08;应用程序编程接口&#xff09;&#xff0c;允许Java程序与数据库交互。它提供了一个标准接口&#xff0c;用于从Java程序连接到关系数据库&#xff08;如MySQL、Oracle和Microsoft SQL Server&#…

银行数字化转型导师坚鹏:商业银行数字化风控(1天)

商业银行数字化风控 课程背景&#xff1a; 数字化背景下&#xff0c;很多银行存在以下问题&#xff1a; 不清楚商业银行数字化风控发展现状&#xff1f; 不清楚对公业务数字化风控工作如何开展&#xff1f; 不知道零售业务数字化风控工作如何开展&#xff1f; 课程特色…

二叉树搜索树详解

定义 二叉搜索树&#xff08;BST&#xff0c;Binary Search Tree&#xff09; 或为一颗空树&#xff0c;或满足一下性质若它的左子树不为空&#xff0c;则左子树上所有节点的值都小于根节点的值若它的右子树不为空&#xff0c;则右子树上所有节点的值都大于根节点的值它的左右…

单测时尽量用fake object

1. 单元测试的难点&#xff1a;外部协作者(external collaborators)的存在 单元测试是软件开发的一个重要部分&#xff0c;它有助于在开发周期的早期发现错误&#xff0c;帮助开发人员增加对生产代码正常工作的信心&#xff0c;同时也有助于改善代码设计。**Go语言从诞生那天起…

C++支持函数重载的原理--名字修饰

这章的原理并不难&#xff0c;前提是你要理解编译和链接。不会的会可以看一下这篇博客快速过一遍。 为什么C支持函数重载&#xff0c;而C语言不支持函数重载呢&#xff1f; 在C/C中&#xff0c;一个程序要运行起来&#xff0c;需要经历以下几个阶段&#xff1a;预处理、编译、汇…

Apache Flink ML 2.2.0 发布公告

来源 | Apache Flink 官方博客 翻译 | 林东 Apache Flink 社区很荣幸地宣布 Apache Flink ML 2.2.0 版本正式发布&#xff01;本次发布的版本重点添加了 Flink ML 中的特征工程算法。现在 Flink ML 包含了 33 个开箱可用的特征工程算法&#xff0c;可以支持很多常见的特征工程任…

springboot,Flowable 流程实例的激活与挂起(一)

一.简介 要实现流程实例的挂起和激活&#xff0c;首先要知道什么是流程实例的挂起和激活。 挂起&#xff1a; ①一个定义好的流程模板&#xff08;流程定义&#xff09;&#xff0c;如果挂起了&#xff0c;那么就无法据此创建新的流程实例。 ② 一个流程实例如果挂起了&#…

Pycharm必会小技巧,用好了都不用加班,效率翻2倍

学Python必用Pycharm&#xff0c;今天就来教大家11个Pycharm最常用的技巧&#xff0c;以及一些pycharm常用的快捷键&#xff0c;让你的写代码的效率翻2倍&#xff0c;以后都不用加班了&#xff01; 跟上老司机的车速&#xff01; 文章目录 一、常用小技巧1.设置代码字体。2.…

Nature:惊人的突破!科学家们成功破译人类嗅觉感应机制的奥秘!

加州大学旧金山分校&#xff08;UCSF&#xff09;的科学家们创造了第一张关于气味分子如何激活人类气味受体的分子水平的3D图片&#xff0c;这是破译嗅觉的关键一步&#xff0c;该成果打破了长期以来研究人员对嗅觉理解的僵局。 该研究成果于2023年3月15日发表在《Nature》&…