墨风如雪博客

  • 源码小店
  • 传家宝VPS
让AI使用变得如此简单
  1. 首页
  2. 算法
  3. 正文

每日一道算法题:判断对称二叉树

2023年 7月 23日 279点热度 0人点赞 0条评论

题目描述

给定一棵二叉树,判断是否是对称二叉树。

解题思路

定义对称二叉树

对称二叉树是指一个二叉树的左右两个子树镜像对称。

递归解法

从根节点开始,判断左右子树是否对称,判断方法是比较左右子树的根节点值是否相等,然后分别递归判断左子树的左子树和右子树的右子树是否对称,左子树的右子树和右子树的左子树是否对称。

非递归解法

使用队列辅助遍历二叉树,每次将左右节点按照对称的方式加入队列中,再逐个比较是否对称。

代码实现

递归解法代码

public boolean isSymmetric(TreeNode root) {
    if (root == null) {
        return true;
    }
    return isSymmetric(root.left, root.right);
}

private boolean isSymmetric(TreeNode left, TreeNode right) {
    if (left == null && right == null) {
        return true;
    }
    if (left == null || right == null || left.val != right.val) {
        return false;
    }
    return isSymmetric(left.left, right.right) && isSymmetric(left.right, right.left);
}

非递归解法代码

public boolean isSymmetric(TreeNode root) {
    if (root == null) {
        return true;
    }
    Queue<TreeNode> queue = new LinkedList<>();
    queue.offer(root.left);
    queue.offer(root.right);
    while (!queue.isEmpty()) {
        TreeNode left = queue.poll();
        TreeNode right = queue.poll();
        if (left == null && right == null) {
            continue;
        }
        if (left == null || right == null || left.val != right.val) {
            return false;
        }
        queue.offer(left.left);
        queue.offer(right.right);
        queue.offer(left.right);
        queue.offer(right.left);
    }
    return true;
}

时间复杂度

递归解法的时间复杂度为O(n),非递归解法的时间复杂度为O(n),其中n为树的节点数。

空间复杂度

递归解法的空间复杂度为O(n),非递归解法的空间复杂度为O(n),其中n为树的节点数。

边界条件处理

当树为空时,判断为对称二叉树。

测试用例

输入:

    1
   / \
  2   2
 / \ / \
3  4 4  3

输出:true

输入:

    1
   / \
  2   2
   \   \
   3    3

输出:false

扩展点

对称二叉树图像的翻转

对于一棵对称二叉树,将其左右子树交换位置后得到的二叉树与原二叉树是镜像对称的。

对称二叉树的遍历

前序遍历:根-左-右,左右子树按照对称顺序遍历

中序遍历:左-根-右,左右子树按照对称顺序遍历

后序遍历:左-右-根,左右子树按照对称顺序遍历

总结

总结解题思路

本题可以使用递归和非递归两种方式解决。递归方式就是比较左右子树是否对称,如果对称则继续递归比较左子树的左子树和右子树的右子树,左子树的右子树和右子树的左子树是否对称。非递归方式需要使用队列辅助,每次将左右节点按照对称的方式加入队列中,再逐个比较是否对称。

总结时间复杂度和空间复杂度

递归解法和非递归解法的时间复杂度和空间复杂度都是O(n),其中n为树的节点数。

总结对称二叉树的应用场景

对称二叉树是一种常见数据结构,其应用场景可以是二叉树镜像的问题,判断两棵树是否相同的问题等等。在算法中也有一些与对称二叉树相关的问题,例如二叉树的最大深度、路径总和等。

本作品采用 知识共享署名 4.0 国际许可协议 进行许可
标签: java 二叉树 动态规划 数组 算法
最后更新:2023年 6月 23日

墨风如雪

一个热爱生活,热爱分享的程序员

打赏 点赞
< 上一篇
下一篇 >

文章评论

您需要 登录 之后才可以评论

墨风如雪

一个热爱生活,热爱分享的程序员

最新 热点 随机
最新 热点 随机
Kimi K2.5开源:自带百人众包团队,月之暗面重新定义生产力 告别修图软件的图层噩梦,腾讯混元3.0让AI学会了“思考” 参数仅100亿却硬刚千亿巨头:阶跃星辰Step3-VL-10B凭什么封神? 腾讯CodeBuddy 2.0:从“副驾驶”到“全栈合伙人”的进化 97毫秒极致响应!Qwen3-TTS开源,重新定义语音生成的“速度与激情” 2026开年王炸:文心5.0带着2.4万亿参数和原生全模态来了
闭源的墙角被挖塌了?GLM-4.7登顶开源王座,这回真不兴嘲讽仅需1GB内存!腾讯混元MT1.5开源,让手机翻译彻底告别云端依赖十天谈下二十亿美金:Meta豪掷千金买下的中国AI天才,到底凭什么?智谱ZCode上手:把Claude和Gemini装进桌面,编程还能这么玩?告别延迟!通义开源Fun-Audio-Chat,这才是我们要的语音AI这可能是最懂人话的AI:阿里MAI-UI让手机自动驾驶成真
别再死磕扩散模型了,MiniMax新开源揭示:视觉Tokenizer才是下一个金矿 华为亮出王牌:70亿参数“特种兵”与720亿“航母”级模型同时开源 DeepWiki 开源版本:AI 帮你自动写代码 Wiki,告别手动苦海! SpringBoot四大核心组件详解 告诉你spring boot 的生命周期是怎么样的(超详细) 震撼业界:文心5.0 Preview登顶全球第二,创意写作能力亮眼!
标签聚合
设计模式 大模型 java 算法 AI spring deepseek 教程

COPYRIGHT © 2023 墨风如雪博客. ALL RIGHTS RESERVED.

Theme Kratos Made By Seaton Jiang