題目:
請實現一個函數,用來判斷一顆二叉樹是不是對稱的。
注意,如果一個二叉樹同此二叉樹的鏡像是同樣的,定義其為對稱的。
思路:
對於一棵二叉樹,從根結點開始遍歷,
如果左右子結點有一個為NULL,那么肯定不是對稱二叉樹;
如果左右子結點均不為空,但不相等,那么肯定不是對稱二叉樹;
如果左右子結點均不為空且相等,那么
遍歷左子樹,遍歷順序為:當前結點,左子樹,右子樹;
遍歷右子樹,遍歷順序為:當前結點,右子樹,左子樹;
如果遍歷左子樹的序列和遍歷右子樹的序列一樣,那么該二叉樹為對稱的二叉樹。(遞歸實現)
另外一種角度考慮:
把每個結點的左右子樹分別看成一棵獨立的二叉樹,那么判斷該二叉樹是否為對稱的,只需判斷左右子樹是否互為鏡像即可。
在線測試OJ:
http://www.nowcoder.com/books/coding-interviews/ff05d44dfdb04e1d83bdbdab320efbcb?rp=3
AC代碼:
/* struct TreeNode { int val; struct TreeNode *left; struct TreeNode *right; TreeNode(int x) : val(x), left(NULL), right(NULL) { } }; */ class Solution { public: bool isSymmetrical(TreeNode* pRoot) { return isSymetrical(pRoot,pRoot); } bool isSymetrical(TreeNode* pLeft,TreeNode* pRight){ if(pLeft==NULL && pRight==NULL) return true; if(pLeft==NULL || pRight==NULL) return false; if(pLeft->val!=pRight->val) return false; return isSymetrical(pLeft->left,pRight->right) && isSymetrical(pLeft->right,pRight->left); } };