当前位置:网站首页>G.登山小分队(暴力&dfs)
G.登山小分队(暴力&dfs)
2022-08-04 14:09:00 【Harris-H】
G.登山小分队(暴力&dfs)
开vector维护到达每个顶点的人的时间。每次排序,更新相同的时间的然后向上合并即可。
#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;
}
边栏推荐
猜你喜欢
漏洞复现 - - - Alibaba Nacos权限认证绕过
MPLS experiment
Rust 从入门到精通04-变量
如何才能有效、高效阅读?猿辅导建议“因材因时施教”
爬虫——selenium基本使用、无界面浏览器、selenium的其他用法、selenium的cookie、爬虫案例
LM2596有没有可以替代的?LM2576可以
节省50%成本!京东云重磅发布新一代混合CDN产品
将 Sentinel 熔断限流规则持久化到 Nacos 配置中心
idea permanent activation tutorial (new version)
《中国综合算力指数》《中国算力白皮书》《中国存力白皮书》《中国运力白皮书》在首届算力大会上重磅发出
随机推荐
Lecture 4 SVN
第四讲 SVN
TS - type
metaRTC5.0新版本支持mbedtls(PolarSSL)
博途1200/1500PLC斜坡指令RAMP(带暂停功能)
华为手机切换屏幕效果_华为p40页面切换效果怎么换
化繁为简,聊一聊复制状态机系统架构抽象
文字编码 - XML 教程
小 P 周刊 Vol.13
AVR学习笔记之熔丝位
四平方和,激光炸弹
《C 陷阱与缺陷 》阅读概要
JSX use
浙江大学团队使用基于知识图谱的新方法,从空间分辨转录组数据中推断细胞间通信状况
并发刺客(False Sharing)——并发程序的隐藏杀手
BZOJ 1798 维护序列 (多校连萌,对线段树进行加乘混合操作)
CCF GLCC正式开营|九州云开源专家携丰厚奖金,助力高校开源推广
基于 Next.js实现在线Excel
Centos7 install mysql version rapidly
c#之winform(软件开发)