平衡二叉树

平衡二叉树

给定一个二叉树,判断它是否是高度平衡的二叉树。本题中,一棵高度平衡二叉树定义为:一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过1

示例#

Copy
给定二叉树 [3,9,20,null,null,15,7] 3 / \ 9 20 / \ 15 7 返回 true
Copy
给定二叉树 [1,2,2,3,3,null,null,4,4] 1 / \ 2 2 / \ 3 3 / \ 4 4 返回 false

题解#

Copy
/** * Definition for a binary tree node. * function TreeNode(val) { * this.val = val; * this.left = this.right = null; * } */ /** * @param {TreeNode} root * @return {boolean} */ var isBalanced = function(root) { var target = true; var dfs = function(root){ if(!root) return 0; if(!target) return 0; var l = dfs(root.left); var r = dfs(root.right); if(Math.abs(l-r)>1) target = false; return l > r ? l+1 : r+1; } dfs(root); return target; };

思路#

定义一个深度递归遍历的函数,在一个节点中获取树的左右子树的高度,也就是定义获取树的高度的函数,在获取左右子树的高度时比较左右子树是否平衡即可,首先定义目标变量target,之后定义深度递归遍历dfs函数,在函数中判断节点不存在则返回0,接下来是一部分剪枝,如果已经找到了不平衡的位置那么就没有必要继续向下遍历,之后定义l为左子树的高度,r为右子树的高度,之后进行比较如果做右子树的高度差大于1则认为其不是平衡二叉树,赋值targetfalse,之后返回做右子树中高的子树的高度+1,执行dfs深度递归遍历,完成后返回target即可。

每日一题#

Copy
https://github.com/WindrunnerMax/EveryDay

参考#

Copy
https://leetcode-cn.com/problems/balanced-binary-tree/
posted @   WindRunnerMax  阅读(95)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示
CONTENTS