-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathleet213.cpp
More file actions
30 lines (30 loc) · 855 Bytes
/
leet213.cpp
File metadata and controls
30 lines (30 loc) · 855 Bytes
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
class Solution {
public:
string s;
int idx = 0, level = 0;
TreeNode* recoverFromPreorder(string traversal) {
s = traversal;
TreeNode* node = new TreeNode(-1);
helper(node, 0);
return node->left;
}
void helper(TreeNode* parent, int lvl) {
while (idx < s.length() && lvl == level) {
int num = 0;
while (idx < s.length() && isdigit(s[idx])) {
num = num * 10 + (s[idx++] - '0');
}
TreeNode* node = new TreeNode(num);
if (!parent->left)
parent->left = node;
else
parent->right = node;
level = 0;
while (idx < s.length() && s[idx] == '-') {
level++;
idx++;
}
helper(node, lvl + 1);
}
}
};