剑指offer之对称的二叉树

本文介绍了一种判断二叉树是否对称的方法,通过对称二叉树的定义出发,利用递归算法实现了该功能。文章详细解释了对称二叉树的条件,并给出了AC代码示例。

题目简介

请实现一个函数,用来判断一颗二叉树是不是对称的。注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的。

解题思路

注意一个点,对称要求对应的值也是相等的。
给出对称二叉树的定义:

  • 空的结点
  • 没有孩子的结点
  • 有两个孩子,且值相等;同时以左右孩子为根的子二叉树也是对称的

递归的代码需要传入两个值,分别是左右孩子,由此来判定是否是对称的,注意理解。

AC代码

class Solution {
  public:
    bool isSymmetrical (TreeNode* pRoot) {
        if (pRoot == nullptr) {
            return true;
        }
        return isSym (pRoot->left, pRoot->right);
    }

    bool isSym (TreeNode* rl, TreeNode* rr) {
        if (rl == nullptr && rr == nullptr) {
            return true;
        } else if (! (rl && rr)) {
            return false;
        } else {
            return rl->val == rr->val && \
                   isSym (rl->left, rr->right) && \
                   isSym (rl->right, rr->left);
        }
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值