给你一个二叉树的根节点 root
, 检查它是否轴对称。
代码如下:
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode() : val(0), left(nullptr), right(nullptr) {}
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
* };
*/
class Solution {
public:
//判断root1和root2是否对称
bool thesame(TreeNode* root1,TreeNode* root2)
{
if(root1==NULL && root2==NULL)
return true;
if(root1==NULL || root2==NULL)
return false;
if(root1->val != root2->val)//根的值不同
return false;
return thesame(root1->left,root2->right) && thesame(root1->right,root2->left);
}
bool isSymmetric(TreeNode* root) {
if(root->left==NULL && root->right==NULL)//只有根
return true;
if(root->left==NULL || root->right==NULL)//只有一个孩子为空
return false;
return thesame(root->left,root->right);
}
};