-
Notifications
You must be signed in to change notification settings - Fork 0
/
Construct_Binary_Tree_from_bracket-string.cpp
90 lines (76 loc) · 1.58 KB
/
Construct_Binary_Tree_from_bracket-string.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
#include <bits/stdc++.h>
using namespace std;
struct Node
{
int data;
Node *left, *right;
};
Node* newNode(int data)
{
Node* node = new Node;
node->data = data;
node->left = node->right = NULL;
return (node);
}
void preOrder(Node* node)
{
if (node == NULL)
return;
printf("%d ", node->data);
preOrder(node->left);
preOrder(node->right);
}
int index = 0;
Node* treeFromString(string s)
{
if(s.size() == 0 or index >= s.size())
return NULL;
// Since root number or any number may be greater than
// 9. So, we must consider whole number. Hence, we will
// run a loop to get whole number.
int number = 0;
while(s[index] != '(' and s[index] != ')' and index < s.size())
{
int digit = (int)(s[index] - '0');
number = number * 10 + digit;
index++;
}
// creating node with the number formed.
Node *root = newNode(number);
// termination condition
if(index >= s.size())
return root;
// constructing left sub-tree.
if(s[index] == '(')
{
index++;
root->left = treeFromString(s);
}
if(s[index] == ')')
{
index++;
return root;
}
// constructing right sub-tree.
if(s[index] == '(')
{
index++;
root->right = treeFromString(s);
}
if(s[index] == ')' )
{
index++;
return root;
}
return root;
}
int main()
{
string str = "4(2(3)(1))(6(5))";
Node* root = treeFromString(str);
preOrder(root);
}
/*
Time complexity = O(N)
Space Complexity = O(1)
*/