题目描述
请实现一个函数,用来判断一颗二叉树是不是对称的。注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的。
思路
前序遍历是:先遍历父结点,在遍历左结点,在遍历右结点;定义对称前序遍历:先遍历父结点,在遍历右结点,在遍历左结点。得到的就是二叉树镜像的前序遍历序列。
只需要比较两种遍历序列就可以判断二叉树是否对称。
C++代码实现
bool isSymmetrical(TreeNode* pRoot)
{
return isSymmetrical(pRoot, pRoot);
}
bool isSymmetrical(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 isSymmetrical(root1->left, root2->right) && isSymmetrical(root1->right,root2->left);
}