题目:
给你一个二叉树的根节点 root , 检查它是否轴对称。
示例 1:
输入:root = [1,2,2,3,4,4,3]
输出:true
示例 2:
输入:root = [1,2,2,null,3,null,3]
输出:false
代码:
/**
* 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:
bool Symmetric(TreeNode *root1,TreeNode *root2)
{
if(root1->val != root2->val)
{
return false;
}
bool one;
bool two;
if(root1->left==NULL && root2->right==NULL)
{
one=true;
}
else
{
if(root1->left!=NULL && root2->right!=NULL)
{
one=Symmetric(root1->left,root2->right);
}
else
{
one=false;
}
}
if(root1->right==NULL && root2->left==NULL)
{
two=true;
}
else
{
if(root1->right!=NULL && root2->left!=NULL)
{
two=Symmetric(root1->right,root2->left);
}
else
{
two=false;
}
}
return (one&&two);
}
bool isSymmetric(TreeNode* root) {
if(root->left==NULL&&root->right==NULL)
{
return true;
}
if(root->left!=NULL && root->right!=NULL)
{
return Symmetric(root->left,root->right);
}
else
{
return false;
}
}
};
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)