LeetCode如何检查二叉树的平衡性
发表于:2025-02-02 作者:千家信息网编辑
千家信息网最后更新 2025年02月02日,这篇文章主要为大家展示了"LeetCode如何检查二叉树的平衡性",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"LeetCode如何检查二叉树的平衡性"这篇
千家信息网最后更新 2025年02月02日LeetCode如何检查二叉树的平衡性
这篇文章主要为大家展示了"LeetCode如何检查二叉树的平衡性",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"LeetCode如何检查二叉树的平衡性"这篇文章吧。
1,问题简述
实现一个函数,检查二叉树是否平衡。
在这个问题中,平衡树的定义如下:
任意一个节点,其两棵子树的高度差不超过 1。
2,示例
示例 1:
给定二叉树 [3,9,20,null,null,15,7]
3
/ \
9 20
/ \
15 7
返回 true 。
示例 2:
给定二叉树 [1,2,2,3,3,null,null,4,4]
1
/ \
2 2
/ \
3 3
/ \
4 4
返回 false 。
3,题解思路
根据递归方式进行解决
4,题解程序
public class IsBalancedTest {
public static void main(String[] args) {
TreeNode t1 = new TreeNode(3);
TreeNode t2 = new TreeNode(9);
TreeNode t3 = new TreeNode(20);
TreeNode t4 = new TreeNode(15);
TreeNode t5 = new TreeNode(7);
t1.left = t2;
t1.right = t3;
t3.left = t4;
t3.right = t5;
boolean balanced = isBalanced(t1);
System.out.println("balanced = " + balanced);
}
public static boolean isBalanced(TreeNode root) {
if (root == null) {
return true;
}
int leftDepth = dfs(root.left);
int rightDepth = dfs(root.right);
int abs = Math.abs(leftDepth - rightDepth);
if (abs <= 1 && isBalanced(root.left) && isBalanced(root.right)) {
return true;
}
return false;
}
private static int dfs(TreeNode root) {
if (root == null) {
return 0;
}
return Math.max(dfs(root.left), dfs(root.right)) + 1;
}
}
5,题解程序图片版
以上是"LeetCode如何检查二叉树的平衡性"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
检查
平衡性
内容
示例
篇文章
题解
程序
问题
学习
帮助
函数
图片
思路
方式
易懂
更多
条理
知识
编带
节点
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
软件开发专业好的大学
天津企业软件开发单价
上海网络技术服务要求
计算机网络技术人员中级职称
其他软件开发属于什么行业分类
江苏品牌网络技术服务电话
数据库的控制有哪些内容
好的软件开发公司都是怎么考核的
什么是数据库安全及数据安全
郑州正规软件开发费用是多少
北京软件开发市场
软件开发相关英语短句
朝阳区网络技术工作室
办公系统软件开发正规平台
济南服务器授权代理
什么是网络安全目标
沈阳学习网络技术
11g新建数据库sid
关于网络安全的手工
服务器时间管理规定
计算机四级数据库工程师上机
树结构 数据库
软件开发智能化是什么
电力系统网络安全事件应急预案
软件开发的图怎么画
黄石功能齐全的计算机软件开发
有关城市外卖的数据库
桂林市火星人网络技术有限公司
csgo查当前服务器指令
魔力宝贝无法连接服务器怎么办