https://leetcode-cn.com/problems/symmetric-tree/
给定一个二叉树,检查它是否是镜像对称的。
例如,二叉树 [1,2,2,3,4,4,3]
是对称的。
1 / \ 2 2 / \ / \ 3 4 4 3
但是下面这个 [1,2,2,null,3,null,3]
则不是镜像对称的:
1 / \ 2 2 \ \ 3 3
说明:
如果你可以运用递归和迭代两种方法解决这个问题,会很加分。
解题方法:与相同二叉树搜索方式一模一样,只需要将左指针与左指针比较改成左指针与右指针。
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* struct TreeNode *left;
* struct TreeNode *right;
* };
*/
bool isSymmetric(struct TreeNode* root) {
return isSameTree(root,root);
}
bool isSameTree(struct TreeNode* p, struct TreeNode* q) {
if(p==NULL && q ==NULL) return true;
if(p!=NULL && q!=NULL && p->val==q->val){
return isSameTree(p->left,q->right) && isSameTree(p->right,q->left);
}
return false;
}//递归代码