news 2026/4/15 13:34:00

【每天学习一点算法 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/12 2:18:47

《创业之路》-741-CTO的核心能力是前瞻性和技术预见能力,对未来机会方向的洞察能力

“CTO的核心能力是前瞻性和技术预见能力&#xff0c;是对未来机会方向的洞察能力。”这不仅是对技术领导者的深刻理解&#xff0c;更是对企业能否穿越周期、持续创新的关键判断。下面我们来系统深化这一观点&#xff0c;将其升华为一套 “CTO前瞻性能力模型” ——不仅说明“是…

作者头像 李华
网站建设 2026/4/14 1:22:29

喷砂除锈设备工艺流程是什么?| 广东鑫百通喷砂机厂家

喷砂除锈设备标准工艺流程&#xff1a;五步实现完美基材 喷砂除锈设备工艺远非简单的“用砂子打表面”&#xff0c;而是一套严谨、高效的系统工程。规范的工艺流程是确保处理质量、控制成本与保障安全的核心。 喷砂除锈设备标准流程可精炼为以下5个关键步骤。 第一步&#xff1…

作者头像 李华
网站建设 2026/4/12 0:17:32

创客匠人:从个人IP到知识变现,如何构建可持续的内容生态?

在知识付费与内容创业浪潮中&#xff0c;越来越多的人开始意识到&#xff1a;单纯的内容输出已不足以构建长期竞争力。无论是讲师、咨询师、行业专家&#xff0c;还是创业者&#xff0c;都面临一个共同问题&#xff1a;如何从“被看见”走向“被选择”&#xff0c;并最终实现可…

作者头像 李华
网站建设 2026/4/12 4:33:23

小程序计算机毕设之基于springboot+java的在线学习网站平台系统小程序基于springboot的智能学习小程序(完整前后端代码+说明文档+LW,调试定制等)

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

作者头像 李华
网站建设 2026/4/13 6:49:23

小程序毕设选题推荐:基于springboot的华兴书城微信小程序线上购书、阅读社交化【附源码、mysql、文档、调试+代码讲解+全bao等】

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

作者头像 李华
网站建设 2026/4/11 14:24:35

计算机小程序毕设实战-基于springboot+微信小程序的宠物领养系统小程序动物信息管理、领养流程审批【完整源码+LW+部署说明+演示视频,全bao一条龙等】

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

作者头像 李华