Java-对称二叉树(递归实现)

一、概念
给定一个二叉树,检查它是否是镜像对称的。
对称二叉树特点:根节点为第一层,从第二层开始:节点值相同,左子树的left和右子树的right是否对称,右子树的left和左子树的right是否对称.
二、举例
在这里插入图片描述
三、代码实现

//对称二叉树:对应节点的值相同&&左右子树要刚好相反
    //和根节点没有关系,看左右子树是否对称:值相等&&左子树.left和右子树.right是否对称&&左子树.right和右子树.left是否对称
    public boolean isSymmetric(TreeNode root) {
        //判断root
        if(root==null){
            return true;
        }
        //判定root是否为对称转换成root.left和root.right是否对称


       return isMirror(root.left,root.right);
    }
    private boolean isMirror(TreeNode t1,TreeNode t2){
        if(t1==null&&t2==null){
            return true;
        }
        if(t1==null||t2==null){
            return false;
        }
        //t1和t2是否对称=》t1.val==t2.val&&t1.left和t2.right对称&&t1.right和t2.left对称
        return (t1.val==t2.val) &&isMirror(t1.left,t2.right)&&isMirror(t1.right,t2.left);
    }

四、递归过程
递归过程

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值