news 2026/7/1 23:04:29

day144—递归—平衡二叉树(LeetCode-110)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
day144—递归—平衡二叉树(LeetCode-110)

题目描述

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

示例 1:

输入:root = [3,9,20,null,null,15,7]输出:true

示例 2:

输入:root = [1,2,2,3,3,null,null,4,4]输出:false

示例 3:

输入:root = []输出:true

提示:

  • 树中的节点数在范围[0, 5000]
  • -104 <= Node.val <= 104

解决方案:

这段代码的核心功能是判断一棵二叉树是否为平衡二叉树(即每个节点的左右子树高度差的绝对值不超过 1),采用「后序遍历 + 递归剪枝」的思路实现,在计算子树高度的同时校验平衡条件,时间复杂度O(n)n为节点数),空间复杂度O(h)h为树的高度),是该问题的最优解法。

核心逻辑

代码将 “计算子树高度” 和 “校验平衡条件” 融合在同一个递归函数中,通过返回特殊值-1实现剪枝,避免重复遍历:

  1. 递归辅助函数node_height:既计算节点的高度,又实时校验平衡条件:
    • 边界条件:空节点高度为0
    • 递归计算左子树高度left_h,若左子树已不平衡(left_h=-1),直接返回-1(剪枝,无需计算右子树);
    • 同理递归计算右子树高度right_h,若右子树不平衡,直接返回-1
    • 校验当前节点平衡条件:若左右子树高度差的绝对值 > 1,返回-1(标记当前子树不平衡);
    • 若平衡,返回当前节点的高度(max(left_h, right_h)+1);
  2. 主函数isBalanced
    • 空树直接返回true(空树是平衡的);
    • 调用node_height(root),若返回值不为-1,说明整棵树平衡,返回true,否则返回false

总结

  1. 核心思路:后序遍历(先算左右子树高度,再判断当前节点),在计算高度的同时校验平衡,用-1剪枝避免无效递归;
  2. 关键优化:相比 “先算所有节点高度,再逐个校验” 的暴力解法,该思路只需一次遍历,时间效率更高;
  3. 效率特点:每个节点仅被访问一次,时间O(n);递归栈空间取决于树的高度,平衡树为O(log n),退化为链表时为O(n)

函数源码:

/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { public: int node_height(TreeNode* node){ if(!node) return 0; int left_h=node_height(node->left); if(left_h==-1){ return -1; } int right_h=node_height(node->right); if(right_h==-1){ return -1; } if(abs(right_h-left_h)>1){ return -1; } return max(left_h,right_h)+1; } bool isBalanced(TreeNode* root) { if(!root) return true; return node_height(root)!=-1; } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/1 7:25:42

【计算机毕业设计案例】基于微信小程序的校园跑腿小程序基于springboot+微信小程序的校园外卖直送平台(程序+文档+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/7/1 7:27:13

Flink Firehose Sink 把实时流数据稳定写进 Amazon Kinesis Data Firehose

1、先看版本坑&#xff1a;Flink 2.2 目前没有可用的 Firehose Connector 如果你正在用 Flink 2.2&#xff0c;官方文档明确写了&#xff1a;Flink 2.2 暂无可用的 Firehose connector&#xff1b;PyFlink 侧也标注 暂无 SQL jar。 (nightlies.apache.org) 如果你用的是已发布…

作者头像 李华
网站建设 2026/7/1 7:27:19

交通仿真软件:VISSIM_(20).交通仿真在交通环境影响评估中的应用

交通仿真在交通环境影响评估中的应用 1. 交通仿真软件在环境影响评估中的重要性 交通环境影响评估&#xff08;Traffic Environmental Impact Assessment, TEIA&#xff09;是城市规划和交通工程中的一个重要环节&#xff0c;旨在评估交通项目对环境的潜在影响。传统的TEIA方法…

作者头像 李华
网站建设 2026/7/1 16:12:58

Linux进阶:玩转文件与权限管理

&#x1f525; 码途CQ&#xff1a; 个人主页 ✨ 个人专栏&#xff1a; 《Linux》 | 《经典算法题集》 《C》 《QT》 ✨ 追风赶月莫停留&#xff0c;无芜尽处是春山! &#x1f496; 欢迎关注&#xff0c;一起交流学习 &#x1f496; &#x1f4cc; 关注后可第一时间获取C/Qt/算…

作者头像 李华
网站建设 2026/6/15 21:48:45

共同探索的价值

共同探索的价值关键词&#xff1a;共同探索、知识共享、创新合作、团队凝聚力、跨领域融合、资源整合、价值创造摘要&#xff1a;本文深入探讨了共同探索在信息技术领域以及更广泛范围内的重要价值。通过详细阐述共同探索的背景、核心概念、算法原理、数学模型、项目实战、应用…

作者头像 李华