题目描述
请实现一个函数,用来判断一颗二叉树是不是对称的。注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的。
分析:从上到下直接遍历,利用栈或者队列暂存结点,注意结点的存和取都是成对的
class Solution { public: bool isSymmetrical(TreeNode* root) { if(root==NULL) return true; stack<TreeNode*> s; s.push(root->left); s.push(root->right); while(s.size()!=0) { TreeNode *left=s.top(); s.pop(); TreeNode *right=s.top(); s.pop(); if(left==NULL&&right==NULL) continue; if(left==NULL&&right!=NULL) return false; if(left!=NULL&&right==NULL) return false; if(left->val!=right->val)//值不相等肯定不是镜像 return false; //左子树的左孩子和右子树的有孩子是一对 s.push(left->left); s.push(right->right); //左子树的右孩子和右子树的左孩子是一对 s.push(left->right); s.push(right->left); } return true; } };