首页 > 其他 > 详细

[Leetcode][Tree][Symmetric Tree]

时间:2014-07-07 13:57:11      阅读:229      评论:0      收藏:0      [点我收藏+]

如果按层次遍历,存下每一层的点,会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

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!