欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

leetcode:对称二叉树

程序员文章站 2022-05-20 11:20:55
...

递归思路:判断一棵树是否对称,即其左子树和右子树是否镜面对称,即左孩子的左子树和右孩子的右子树、左孩子的右子树和右孩子的左子树是否镜面对称…

利用两个指针传参,t1指向左,t2指向右
若两个指针指向节点值相同则可以继续向下递归,如果不同则并非镜面对称。

/**

  • Definition for a binary tree node.
  • struct TreeNode {
  • int val;
    
  • struct TreeNode *left;
    
  • struct TreeNode *right;
    
  • };
    /
    bool SymmetricTree(struct TreeNode
    t1,struct TreeNode* t2)
    {
    if(t1NULL&&t2NULL)return true;
    if(t1NULL||t2NULL)return false;
    //判断t1和t2是否相同
    //相同即向下递归,否则return false
    if(t1->val==t2->val)
    {
    return SymmetricTree(t1->left,t2->right)&&SymmetricTree(t1->right,t2->left);
    }
    return false;
    }

bool isSymmetric(struct TreeNode* root){
//一棵树是否对称,即其左子树和右子树是否相同,依次递归
if(root==NULL)
{
return true;
}
return SymmetricTree(root,root);
}

作者:yYkQM1nCyc
链接:https://leetcode-cn.com/problems/symmetric-tree/solution/dui-cheng-er-cha-shu-c-by-yykqm1ncyc/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。