(C++版)剑指offer——对称的二叉树

题目描述

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

思路

本文分递归与非递归两种方式实现

/*递归
  思路:首先根节点以及其左右子树,左子树的左子树和右子树的右子树相同
* 左子树的右子树和右子树的左子树相同即可
*/
class Solution {
public:
    bool Compare(TreeNode* left,TreeNode* right){
        if(left == NULL && right == NULL)
            return true;
        if(left == NULL || right == NULL)
            return false;
        return left->val == right->val && Compare(left->left,right->right)
            && Compare(left->right,right->left);
    }
    bool isSymmetrical(TreeNode* pRoot)
    {
        if(pRoot == NULL)
            return true;
        return Compare(pRoot->left,pRoot->right);
    }

};


猜你喜欢

转载自blog.csdn.net/qq_31248309/article/details/86063894