1.迭代法
分析:队列层序遍历,一次出队列两个,按左左 ,右右,左右,右左,的顺序入队

cpp
bool idsyme(TreeNode* root){
if(root==NULL) return true;
queue<TreeNode*> q;
q.push(root->left);
q.push(root->right);
while (!q.empty()) {
TreeNode* leftnode = q.front();
q.pop();
TreeNode* rightnode = q.front();
q.pop();
if (leftnode == NULL && rightnode == NULL){
continue;
}
if (leftnode==NULL || rightnode==NULL||(leftnode->val != rightnode->val))
{
return false;
}
q.push(leftnode->left);
q.push(rightnode->right);
q.push(leftnode->right);
q.push(rightnode->left);
}
return true;
}
2.递归法
递归入口是两个节点,因此我们重新写一个函数进行递归,参数有两个节点,对根的左子树和右子树进行递归,画basecase的时候记得要画有两个节点可以进入递归的情况,如图

可以看到一些不对称的条件,如代码中的条件
cpp
bool isSymmetric(TreeNode* root) {
if(root==NULL) return true;
return fun(root->left,root->right);
}
bool fun(TreeNode* l,TreeNode* r){
if(l==NULL && r==NULL) return true;
if((l==NULL&&r!=NULL) || (l!=NULL && r==NULL)||l->val!=r->val){
return false;
}
bool a = fun(l->left,r->right);
bool b = fun(l->right,r->left);
return a&&b;
}
};