如果按层次遍历,存下每一层的点,会MLE。
1、递归版本:关键还是子问题的划分。
1 /** 2 * Definition for binary tree 3 * struct TreeNode { 4 * int val; 5 * TreeNode *left; 6 * TreeNode *right; 7 * TreeNode(int x) : val(x), left(NULL), right(NULL) {} 8 * }; 9 */ 10 class Solution { 11 public: 12 bool symmetric(TreeNode * leftnode, TreeNode * rightnode) { 13 if (leftnode == NULL && rightnode == NULL) { 14 return true; 15 } 16 if (leftnode == NULL || rightnode == NULL) { 17 return false; 18 } 19 if (leftnode->val != rightnode->val) { 20 return false; 21 } 22 return symmetric(leftnode->left, rightnode->right) && 23 symmetric(leftnode->right, rightnode->left); 24 } 25 bool isSymmetric(TreeNode *root) { 26 if (root == NULL) { 27 return true; 28 } else { 29 return symmetric(root->left, root->right); 30 } 31 } 32 };
2、迭代版本:思路很巧妙,不看题解自己真的想不出来。。对自己的智商好捉急。。
1 /** 2 * Definition for binary tree 3 * struct TreeNode { 4 * int val; 5 * TreeNode *left; 6 * TreeNode *right; 7 * TreeNode(int x) : val(x), left(NULL), right(NULL) {} 8 * }; 9 */ 10 class Solution { 11 public: 12 bool isSymmetric(TreeNode *root) { 13 queue<TreeNode *> q; 14 if (root == NULL) { 15 return true; 16 } else { 17 q.push(root->left); 18 q.push(root->right); 19 } 20 while (!q.empty()) { 21 TreeNode * n1 = q.front(); 22 q.pop(); 23 TreeNode * n2 = q.front(); 24 q.pop(); 25 if (n1 == NULL && n2 == NULL) { 26 continue; 27 } 28 if (n1 == NULL || n2 == NULL) { 29 return false; 30 } 31 if (n1->val != n2->val) { 32 return false; 33 } 34 q.push(n1->left); 35 q.push(n2->right); 36 q.push(n1->right); 37 q.push(n2->left); 38 } 39 return true; 40 } 41 };
[Leetcode][Tree][Symmetric Tree],布布扣,bubuko.com
[Leetcode][Tree][Symmetric Tree]
原文地址:http://www.cnblogs.com/poemqiong/p/3815392.html