输入样例1
3
1 2
1 3
输出样例1
1
输入样例2
4
1 2
2 3
2 4
输出样例2
3
如何处理多个结点同时到达该结点,及该结点如何递交给父结点为关键问题。
令 g g g 中最后维护的是人从该结点离开的时刻,则容易得到到达父结点的时刻即为从儿子结点的离开时刻 + 1 +1 +1
由于同一单位时间内,一条通路上只允许一个人通过,则对于到达该结点的时刻相同的人,需要错开其离开结点的时刻,该操作可通过先排序再进行处理
例:样例 2 2 2 中,两人到达结点 2 2 2 的时刻为 1 , 1 1,1 1,1,处理后得到离开结点 2 2 2 的时刻为 1 , 2 1,2 1,2,则到达结点 1 1 1 的时刻为 2 , 3 2,3 2,3
#include <bits/stdc++.h>
#define int long long
using namespace std;
const int N = 5e5 + 5;
int n, u, v, x;
vector<int> vec[N], g[N];
void dfs(int x, int fa) {
int flag = 1;
for (auto y : vec[x]) {
if (y == fa)
continue;
dfs(y, x);
flag = 0;
}
if (flag) //叶
g[x].push_back(0);
sort(g[x].begin(), g[x].end());
if (x != 1) {
int len = g[x].size();
for (int i = 1; i < len; i++) //当前结点 处理到达时间相同的
g[x][i] = max(g[x][i], g[x][i - 1] + 1);
for (auto v : g[x]) //+1递交给父结点
g[fa].push_back(v + 1);
}
}
signed main() {
cin >> n;
for (int i = 1; i < n; i++) {
cin >> u >> v;
vec[u].push_back(v);
vec[v].push_back(u);
}
dfs(1, -1);
// for (int i = 1; i <= n; i++) {
// cout << i << ":" << endl;
// for (auto x : g[i])
// cout << x << " ";
// cout << endl;
// }
cout << g[1][g[1].size() - 1];
return 0;
}