-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path02 January Maximum Value
43 lines (43 loc) · 1.25 KB
/
02 January Maximum Value
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
class Solution {
public:
void traverse(Node* node, vector<int>& ans, int level ){
if(node == NULL )
return;
if(ans.size()>=level){
ans[level-1] = max(node->data, ans[level-1]);
}
else{
ans.push_back(node->data);
}
traverse(node->left, ans, level+1);
traverse(node->right, ans, level+1);
}
// Takes O(n) Time complexity and O(H) space complexity
void dfs(Node* node, vector<int>&ans){
if (node==NULL)
return;
stack<pair<Node*, int>> s;
s.push({node, 1});
while(!s.empty()){
auto it = s.top();
s.pop();
if(ans.size()>=it.second){
ans[it.second-1] = max(it.first->data, ans[it.second-1]);
}
else{
ans.push_back(it.first->data);
}
if(it.first->left != NULL )
s.push({it.first->left, it.second+1});
if(it.first->right != NULL )
s.push({it.first->right, it.second+1});
}
}
vector<int> maximumValue(Node* node) {
vector<int> ans;
// int level = 1;
// traverse(node, ans, level);
dfs(node, ans);
return ans;
}
};