题目描述
给定一个二叉树,检查它是否是镜像对称的。
例如,二叉树 [1,2,2,3,4,4,3] 是对称的。
但是下面这个 [1,2,2,null,3,null,3] 则不是镜像对称的:
来源:力扣
链接:对称二叉树
代码示例:
bool _cmpTree(struct TreeNode *p, struct TreeNode *q)//判断两个二叉树是否呈镜像对称的函数
{
if (p == NULL && q == NULL)
{
return true;
}
if (p == NULL || q == NULL)
{
return false;
}
if (p->val != q->val)
{
return false;
}
return _cmpTree(p->left, q->right) && _cmpTree(p->right, q->left);
}
bool isSymmetric(struct TreeNode* root){
if (root == NULL)
{
return true;
}
return _cmpTree(root->left, root->right);
}