Leetcode[树] 101. 对称二叉树

Leetcode[树] 101. 对称二叉树

审题

给定一个二叉树,检查它是否是镜像对称的。

例如,二叉树 [1,2,2,3,4,4,3] 是对称的。

    1
   / \
  2   2
 / \ / \
3  4 4  3
 	
但是下面这个 [1,2,2,null,3,null,3] 则不是镜像对称的:

    1
   / \
  2   2
   \   \
   3    3

进阶:

你可以运用递归和迭代两种方法解决这个问题吗?

依旧是一个树的简单题,这个题里面,看到是否是镜像对称,我们可以想到判断两个树是否相同的时候用的递归方法,而这道题比上一道题稍有不同,然而还是可以依靠相同的思路实现,我们看代码来进一步说明。

代码实现

方案一(上文提到的的方法):
这里面,看似码量比上一道题要大不少,但实际上核心代码只有isSymmetric2函数中的核心代码,剩下的都是特判。

比如:在根节点传进来的时候,我们要判断是否为空,然后判断根的左子树,右子树是否为空,值是否相等,只有满足了上述条件之后,我们才能够进入递归的部分。

递归函数的具体实现就是,当前层次上的两个对应的结点看偏左的结点的左结点是否等于偏右结点的右结点,以及偏左结点的右结点是否等于偏右结点的左结点,直到最后一层。

当然,如果结点一个空一个不空,我们同样也要返回false,因为一定是镜像不对称的了,由上述可有如下代码:

class Solution {
public:
    bool isSymmetric2(TreeNode* t1, TreeNode* t2) {
        if ( t1 == NULL && t2 == NULL ) {
            return true;
        } else if ( t1 == NULL || t2 == NULL ) {
            return false;
        } else if ( t1->val != t2->val ) {
            return false;
        } else {
            return isSymmetric2(t1->left, t2->right) && isSymmetric2(t1->right, t2->left);
        }
    }
    bool isSymmetric(TreeNode* root) {
        if ( !root ) return true;
        if ( root->left == NULL && root->right == NULL ) {
            return true;
        } else if ( root->left == NULL || root->right == NULL ) {
            return false;
        } else if ( root->left->val != root->right->val ) {
            return false;
        } else {
           return isSymmetric2(root->left, root->right); 
        }
    }
};

方案2:
官方题解的思路差不多,不过这一步很巧妙,可以利用函数的特点,传入两个根,这样虽然多比较了一次,但是代码的清晰度明显增加了不少,小技巧学习了~

class Solution {
public:
    bool isSymmetric2(TreeNode* t1, TreeNode* t2) {
        if ( t1 == NULL && t2 == NULL ) {
            return true;
        } else if ( t1 == NULL || t2 == NULL ) {
            return false;
        } else if ( t1->val != t2->val ) {
            return false;
        } else {
            return isSymmetric2(t1->left, t2->right) && isSymmetric2(t1->right, t2->left);
        }
    }
    bool isSymmetric(TreeNode* root) {
        return isSymmetric2(root, root);
    }
};

反思

这次依旧是对树的递归遍历的一次实践,没啥好说的,加深了一点点树和递归的理解。

那么树的简单题就做到这里,感觉再做对于码力的提升也不大了,下一篇博客我们来挑战中等难度的题。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值