-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsumOfDistancesInTree.cpp
More file actions
50 lines (43 loc) · 1.28 KB
/
sumOfDistancesInTree.cpp
File metadata and controls
50 lines (43 loc) · 1.28 KB
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
class Solution {
public:
vector<int> sumOfDistancesInTree(int N, vector<vector<int>>& edges) {
cnt = vector<int>(N, 1);
dist = vector<int>(N, 0);
g = vector<vector<int> >(N);
num = N;
for(auto &i : edges){
g[i[0]].push_back(i[1]);
g[i[1]].push_back(i[0]);
}
dfs(0, -1);
fun(0, -1);
return dist;
}
void fun(int root, const int fa){
if(fa != -1)
dist[root] = dist[fa] + num - cnt[root] - cnt[root];
for(int i : g[root]){
if(i == fa)
continue;
fun(i, root);
}
}
void dfs(int root, const int fa){
for(int i: g[root]){
if(i == fa)
continue;
dfs(i, root);
cnt[root] += cnt[i];
dist[root] += dist[i];
}
dist[root] += cnt[root] - 1;
}
private:
vector<int> cnt, dist;
vector<vector<int> > g;
int num;
};
// 作者:Computer Science Global Optim
// 链接:https://leetcode.cn/problems/sum-of-distances-in-tree/solutions/659887/c-dfsling-lei-jie-fa-by-raymond_yp-ijw9/
// 来源:力扣(LeetCode)
// 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。