Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its center).

For example, this binary tree [1,2,2,3,4,4,3] is symmetric:


 

But the following [1,2,2,null,3,null,3] is not:


 

Note:
Bonus points if you could solve it both recursively and iteratively.

 

题解:递归比较二者的子树

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */
bool ju(struct TreeNode* a,struct TreeNode* b){
      if(a->val == b->val)
      {
          if((a->left==NULL&&b->right==NULL)||(a->left!=NULL&&b->right!=NULL&&ju(a->left,b->right)))
          {
              if((b->left==NULL&&a->right==NULL)||(b->left!=NULL&&a->right!=NULL&&ju(b->left,a->right)))
                  return true;
              else
                  return false;
          }
          else
              return false;
         
      }
    return false;
}
bool isSymmetric(struct TreeNode* root) {
    
    if(root==NULL) return true;
    if((root->left==NULL&&root->right==NULL)||(root->left!=NULL&&root->right!=NULL&&ju(root->left,root->right)))
        return true;
    else
       return false;
    
}

 

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-06-08
  • 2021-10-01
  • 2022-01-05
猜你喜欢
  • 2021-06-23
  • 2021-08-30
  • 2021-11-09
  • 2021-11-29
  • 2021-11-28
  • 2021-07-30
  • 2022-03-02
相关资源
相似解决方案