-
Notifications
You must be signed in to change notification settings - Fork 160
/
Copy pathVertical sum in a binary tree.cpp
102 lines (61 loc) · 2.07 KB
/
Vertical sum in a binary 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
101
/*
Given a Binary Tree, find vertical sum of the nodes that are in same vertical line. Print all sums of different vertical lines.
Examples:
1
/ \
2 3
/ \ / \
4 5 6 7
Vertical-Line-1 vertical sum is 4
Vertical-Line-2: vertical sum is 2
Vertical-Line-3: vertical sum is 1+5+6 = 12
Vertical-Line-4: vertical sum is 3
Vertical-Line-5: vertical sum is 7
*/
/*
solutuion: calculate horizontal distances from root for all nodes. If two nodes have the same horizontal distance, then they are on same vertical line.
HD for root is 0, a right edge (edge connecting to right subtree) is considered as +1 horizontal distance and a left edge is considered as -1 horizontal distance.
Do an inorder traversal and calcuate the horizontal distance recursively.
O(n) time, O(n) space
*/
#include<iostream>
#include<unordered_map>
using namespace std;
struct Node {
int val;
Node *plft;
Node *prgt;
Node(int v) : val(v), plft(NULL), prgt(NULL) {}
};
void GetHorizontalDistance(Node *root, int hd, unordered_map<int, int> &hdmp) {
if (root == NULL) return;
GetHorizontalDistance(root->plft, hd - 1, hdmp);
int prevsum = (hdmp.find(hd) == hdmp.end()) ? 0 : hdmp.find(hd)->second;
if (hdmp.find(hd) == hdmp.end()) {
hdmp.insert(make_pair<int,int>(hd, prevsum + root->val));
} else {
hdmp[hd] = prevsum + root->val;
}
GetHorizontalDistance(root->prgt, hd + 1, hdmp);
}
void VerticalSum(Node *root) {
if (root == NULL) return;
unordered_map<int, int> hdmp;
GetHorizontalDistance(root, 0, hdmp);
if (!hdmp.empty()) {
for (unordered_map<int, int>::iterator it = hdmp.begin(); it != hdmp.end(); ++it ) {
cout<< it->second <<" "<<endl;
}
}
}
int main() {
Node *root = new Node(1);
root->plft = new Node(2);
root->prgt = new Node(3);
root->plft->plft = new Node(4);
root->plft->prgt = new Node(5);
root->prgt->plft = new Node(6);
root->prgt->prgt = new Node(7);
VerticalSum(root);
return 0;
}