news 2026/4/18 5:13:58

【每天学习一点算法 2025/12/18】对称二叉树

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【每天学习一点算法 2025/12/18】对称二叉树

每天学习一点算法 2025/12/18

题目:对称二叉树

给你一个二叉树的根节点root, 检查它是否轴对称。

  1. 老规矩先来递归, 检查二叉树是否轴对称,我们是不是得比较根节点下面得两个子树是否是轴对称,那么我们只需要递归比较两个子树的值即可,那要怎么传参呢?首先肯定是要将根节点的两个子节点作为初始传参传进去的,那么我们需要一个辅助函数,然后每次递归对称传递子结点比较。

    functionisSymmetric(root:TreeNode|null):boolean{if(!root)returntrue;// 空树默认为true// 定义辅助函数 递归比较两个子树functionvalidate(left:TreeNode|null,right:TreeNode|null):boolean{// 两个子节点同时为空才有轴对称的可能if(!left&&!right)returntrue;if(!left||!right)returnfalse;// 比较左右子节点的值,并传递对称的子节点递归returnleft.val===right.val&&validate(left.left,right.right)&&validate(left.right,right.left);}// 调用辅助函数returnvalidate(root.left,root.right);};
  2. 还有我们是不是可以用层序遍历的方法取得每一层的节点然后我们校验他们是否是对称就行了。核心思想其实跟递归是一样的,找到对称节点作比较。

    如果我们拓展下一层按照左左↔右右、左右↔右左的顺序入队列,那么每两个节点都是对称位置上的节点了,比如说我们有一个四层的结构对称的树,像下面这个样。

    1 / \ 2 3 / \ / \ 4 5 6 7 / \ / \ / \ / \ 8 9 10 11 12 13 14 15
    • 我们初始两个子节点入队列:[2, 3]
    • 然后2, 3出队列,子节点按照左左↔右右、左右↔右左的顺序入队列:[4, 7, 5, 6]
    • 然后4, 7出队列,子节点按照左左↔右右、左右↔右左的顺序入队列:[5, 6, 8, 15, 9, 14]
    • 然后5, 6出队列,子节点按照左左↔右右、左右↔右左的顺序入队列:[8, 15, 9, 14, 10, 13, 11, 12]
    • 然后剩下的子节点两两出队列。

    可以看到整个循环的过程子节点的遍历是从上到下,每层从两端向中间收拢的,我们按照这种方式遍历比较两两出队列的节点值就可判断出树是否对称。

    functionisSymmetric(root:TreeNode|null):boolean{// 空树默认为对称if(!root)returntrue;// 初始化队列,用于层序遍历对称位置的节点constqueue:Array<TreeNode|null>=[];// 根节点的左右子节点都为空,是对称树if(!root.left&&!root.right)returntrue;// 根节点的左右子节点只有一个为空,必然不对称if(!root.left||!root.right)returnfalse;// 将根节点的左右子节点(对称的起始节点)入队queue.push(root.left);queue.push(root.right);// 层序遍历队列中的对称节点对while(queue.length){// 每次取出队列前两个节点(一对对称节点)constleft=queue.shift()!;constright=queue.shift()!;// 两个节点都为空,说明当前对称位置无节点,继续检查下一对if(!left&&!right)continue;// 不对称的情况:// 1. 其中一个节点为空,另一个非空// 2. 两个节点值不相等if((!left||!right)||(left.val!==right.val))returnfalse;// 按对称规则将下一层节点入队:// 左节点的左子节点对应右节点的右子节点queue.push(left.left);queue.push(right.right);// 左节点的右子节点对应右节点的左子节点queue.push(left.right);queue.push(right.left);}// 所有对称节点对都验证通过,说明是对称二叉树returntrue;}

题目来源:力扣(LeetCode)

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

从核工业到精密装配:Haption力反馈设备的多元化应用场景

在机器人遥操作研究中&#xff0c;如何超越视觉局限&#xff0c;实现“所见即所感”的精准控制是一大挑战。Haption Virtuose 6D TAO工业级力反馈设备&#xff0c;通过引入关键的力觉维度&#xff0c;为这一领域提供了高效的解决方案。 核心优势&#xff1a;硬核性能与广泛兼容…

作者头像 李华
网站建设 2026/4/18 5:07:55

RAG技术深度解析:工程师必学必收藏的完整指南

RAG技术深度解析&#xff1a;工程师必学必收藏的完整指南 文章全面介绍RAG&#xff08;检索增强生成&#xff09;技术&#xff0c;从基本原理到实践应用。详细讨论索引构建、多路召回策略&#xff08;BM25、Embedding、Graph、CLIP&#xff09;、Rerank模型和Embedding训练方法…

作者头像 李华
网站建设 2026/4/18 5:10:18

小程序计算机毕设之基于小程序的高校学生公寓道闸管理平台的设计与实现(完整前后端代码+说明文档+LW,调试定制等)

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

作者头像 李华
网站建设 2026/4/18 5:09:25

小程序计算机毕设之基于SpringBoot的宠物识别小程序的设计与实现基于springboot的ai识别宠物小程序(完整前后端代码+说明文档+LW,调试定制等)

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

作者头像 李华
网站建设 2026/4/16 12:39:49

注册就翻车?速卖通买家号暗藏高危操作!”

你以为注册速卖通账号就是填填资料&#xff0c;收个验证码&#xff1f;太天真&#xff01;很多账号刚注册就被限制、测评订单被砍&#xff0c;甚至直接被冻结。 你的时间、精力、测评资源&#xff0c;可能在眨眼间化为零。问题不在你填了什么&#xff0c;而在你的账号看起来像不…

作者头像 李华
网站建设 2026/4/15 18:25:01

【课程设计/毕业设计】基于springboot+vue+微信小程序的宠物领养系统基于springboot+微信小程序的宠物领养系统小程序【附源码、数据库、万字文档】

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

作者头像 李华