-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathleetcode-100-Same_Tree.cpp
63 lines (49 loc) · 1.38 KB
/
leetcode-100-Same_Tree.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
/* -- Id = 100 -- */
#include <cstdlib>
#include <iostream>
#include <string>
// Definition for a binary tree node.
struct TreeNode
{
int val;
TreeNode *left;
TreeNode *right;
TreeNode() : val(0), left(nullptr), right(nullptr) {}
TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
};
bool isSameTree(TreeNode* p, TreeNode* q) {
if (!p && !q)
return true;
if ((p != nullptr && q == nullptr)||
(p == nullptr && q != nullptr)||
(p->val != q->val))
return false;
return !(!isSameTree(p->left, q->left)||
!isSameTree(p->right, q->right));
}
int main(int argc, char const *argv[])
{
TreeNode* root1 = new TreeNode;
TreeNode* tl1 = new TreeNode;
TreeNode* tl2 = new TreeNode;
root1->val = 1;
tl1->val = 2;
tl2->val = 1;
root1->left = tl1;
root1->right = tl2;
tl1->left = tl1->right = nullptr;
tl2->left = tl2->right = nullptr;
TreeNode* root2 = new TreeNode;
TreeNode* tr1 = new TreeNode;
TreeNode* tr2 = new TreeNode;
root2->val = 1;
tr1->val = 1;
tr2->val = 2;
root2->left = tr1;
root2->right = tr2;
tr1->left = tr1->right = nullptr;
tr2->left = tr2->right = nullptr;
std::cout << isSameTree(root1, root2) << std::endl;
return EXIT_SUCCESS;
}