news 2026/5/1 8:54:38

LeetCode 分类刷题:110. 平衡二叉树

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode 分类刷题:110. 平衡二叉树

题目

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

解析

// 怎么递归?

// 左右子树的高度相差不超过1

// 递归计算左、右子树的高度,如果高度相差超过1,返回-1;否则正常返回树的高度

// 递归终止条件:节点为空 或 已经检测出某棵子树不平衡

答疑
问:代码中的 −1 是怎么产生的?怎么返回的?

答:在某次递归中,发现左右子树高度绝对差大于 1,我们会返回 −1这个 −1 会一路向上不断返回,直到根节点。

作者:灵茶山艾府
链接:https://leetcode.cn/problems/balanced-binary-tree/solutions/2015068/ru-he-ling-huo-yun-yong-di-gui-lai-kan-s-c3wj/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

答案

这里一开始没写对,因为leftH 和 rightH没有声明类型!!!不止犯一次的错误了!!!

为什么必须加let / const

  • 在 JavaScript 中,未声明的变量会成为全局变量(即使在函数内部)。
  • 递归时,leftHrightH会被错误地覆盖(例如:第一次递归的leftH会污染后续递归的leftH),导致高度计算错误。
/** * Definition for a binary tree node. * function TreeNode(val, left, right) { * this.val = (val===undefined ? 0 : val) * this.left = (left===undefined ? null : left) * this.right = (right===undefined ? null : right) * } */ /** * @param {TreeNode} root * @return {boolean} */ var isBalanced = function(root) { function f(node) { if(node === null) return 0; const leftH = f(node.left); if(leftH === -1) return -1; const rightH = f(node.right); if(rightH === -1 || Math.abs(leftH - rightH) > 1) return -1; return Math.max(leftH, rightH) + 1; } return f(root) !== -1; };

复杂度分析

时间复杂度:O(n),其中 n 为二叉树的节点个数。

空间复杂度:O(n)。最坏情况下,二叉树退化成一条链,递归需要 O(n) 的栈空间。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/28 4:01:22

CRT-Royale 重塑游戏视觉:从物理模拟到艺术创造的完整指南

在现代游戏追求极致画质的今天,CRT-Royale 着色器为玩家提供了一条通往复古视觉体验的独特路径。这个基于物理模拟的高级着色器项目,通过精确重现老式显示器的光学特性,为任何现代游戏注入经典的视觉灵魂。 【免费下载链接】crt-royale-resha…

作者头像 李华
网站建设 2026/5/1 8:52:42

SetEdit终极指南:5分钟学会掌控Android系统设置

SetEdit终极指南:5分钟学会掌控Android系统设置 【免费下载链接】SetEdit Open source version of the original Settings Database Editor 项目地址: https://gitcode.com/gh_mirrors/se/SetEdit SetEdit是一款开源的Android系统设置编辑器,让普…

作者头像 李华
网站建设 2026/5/1 5:19:20

CyberdropBunkrDownloader:批量下载Cyberdrop和Bunkr文件的终极指南

CyberdropBunkrDownloader:批量下载Cyberdrop和Bunkr文件的终极指南 【免费下载链接】CyberdropBunkrDownloader Simple downloader for cyberdrop.me and bunkrr.sk 项目地址: https://gitcode.com/gh_mirrors/cy/CyberdropBunkrDownloader 你是否曾经需要从…

作者头像 李华
网站建设 2026/5/1 5:20:45

VSCode日志分析实战(量子算法性能瓶颈的4个信号)

第一章:VSCode日志分析与量子算法性能监控概述在现代软件开发与科研计算融合的背景下,集成开发环境(IDE)不仅承担代码编写任务,更成为复杂算法调试与系统行为分析的核心平台。Visual Studio Code(VSCode&am…

作者头像 李华
网站建设 2026/5/1 5:20:40

NarratoAI:零基础也能制作专业级视频解说的智能工具

NarratoAI:零基础也能制作专业级视频解说的智能工具 【免费下载链接】NarratoAI 利用AI大模型,一键解说并剪辑视频; Using AI models to automatically provide commentary and edit videos with a single click. 项目地址: https://gitcod…

作者头像 李华
网站建设 2026/5/1 5:20:42

MikroTikPatch终极指南:轻松管理RouterOS 7.19.1 arm64版本

MikroTikPatch终极指南:轻松管理RouterOS 7.19.1 arm64版本 【免费下载链接】MikroTikPatch 项目地址: https://gitcode.com/gh_mirrors/mikr/MikroTikPatch MikroTikPatch是一个专注于MikroTik RouterOS系统补丁和版本管理的开源项目,为网络管理…

作者头像 李华