-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path100. Same Tree.cpp
100 lines (64 loc) · 2.13 KB
/
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#include<vector>
#include<iostream>
#include<stack>
using namespace std;
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) {}
};
class Solution {
public:
bool isSameTreeIterative(TreeNode* p, TreeNode* q){
stack<pair<TreeNode*,TreeNode*>> s;
s.push({p,q});
while(s.size()>0){
TreeNode* p_cur = s.top().first;
TreeNode* q_cur = s.top().second;
s.pop();
if(p_cur && q_cur && p_cur->val == q_cur->val){
s.push({p_cur->left,q_cur->left});
s.push({p_cur->right,q_cur->right});
}
else if (p_cur || q_cur){
return false;
}
}
return true;
}
bool isSameTreeRecursive(TreeNode* p, TreeNode* q){
if(!p && !q){
return true;
}
if(!p || !q || p->val != q->val){
return false;
}
return isSameTree(p->left,q->left) && isSameTree(p->right,q->right);
}
bool isSameTree(TreeNode* p, TreeNode* q) {
// return isSameTreeRecursive(p,q);
return isSameTreeIterative(p,q);
}
};
int main(){
Solution solution;
// TreeNode* p_root = new TreeNode(1);
// TreeNode* q_root = new TreeNode(1);
// p_root->left = new TreeNode(2);
// q_root->right = new TreeNode(2);
TreeNode* p_root = new TreeNode(1);
TreeNode* p2 = new TreeNode(2);
TreeNode* p3 = new TreeNode(3);
p_root->left = p2;
p_root->right = p3;
TreeNode* q_root = new TreeNode(1);
TreeNode* q2 = new TreeNode(2);
TreeNode* q3 = new TreeNode(3);
q_root->left = q2;
q_root->right = q3;
bool answer = solution.isSameTree(p_root,q_root);
cout << "Answer: " << answer << endl;
}