一颗树n个点,n-1条边,经过每条边都要花费一定的时间,任意两个点都是联通的。
有K个人(分布在K个不同的点)要集中到一个点举行聚会。
聚会结束后需要一辆车从举行聚会的这点出发,把这K个人分别送回去。
请你回答,对于i=1~n,如果在第i个点举行聚会,司机最少需要多少时间把K个人都送回家。
标签:cst amp return 个数 logs ring 多少 情况 font
#include <cstdio> #include <cstring> #include <iostream> #include <algorithm> using namespace std; const int maxn = 500010; int n, k,head[maxn],to[maxn * 2],nextt[maxn * 2],w[maxn * 2],tot = 1,ner[maxn],son[maxn]; long long mind[maxn],maxd[maxn],secd[maxn],d[maxn],sum; bool flag[maxn],vis[maxn]; void add(int x, int y, int z) { w[tot] = z; to[tot] = y; nextt[tot] = head[x]; head[x] = tot++; } bool dfs1(int x) //找树 { vis[x] = 1; for (int i = head[x]; i; i = nextt[i]) { int v = to[i]; if (!vis[v]) { if (dfs1(v)) { flag[x] = 1; sum += w[i]; } } } return flag[x]; } void dfs2(int x) //找最短距离 { vis[x] = 1; if (flag[x]) ner[x] = x; for (int i = head[x]; i; i = nextt[i]) { int v = to[i]; if (!vis[v] && !flag[v]) { mind[v] = mind[x] + w[i]; ner[v] = ner[x]; } if (!vis[v]) dfs2(v); } } long long dfs3(int x) //最长距离+次长距离 { vis[x] = 1; for (int i = head[x]; i; i = nextt[i]) { int v = to[i]; if (!vis[v] && flag[v]) { long long t = dfs3(v) + w[i]; if (t > maxd[x]) { secd[x] = maxd[x]; maxd[x] = t; son[x] = v; } else if (t > secd[x]) secd[x] = t; } } return maxd[x]; } void dfs4(int x, long long lmax) //最后的更新 { vis[x] = 1; for (int i = head[x]; i; i = nextt[i]) { int v = to[i]; d[x] = max(lmax, maxd[x]); if (flag[v] && !vis[v]) { if (v == son[x]) dfs4(v, max(lmax, secd[x]) + w[i]); else dfs4(v, max(lmax, maxd[x]) + w[i]); } } } int main() { memset(flag, false, sizeof(flag)); scanf("%d%d", &n, &k); for (int i = 1; i < n; i++) { int x, y, z; scanf("%d%d%d", &x, &y, &z); add(x, y, z); add(y, x, z); } int t; for (int i = 1; i <= k; i++) { scanf("%d", &t); flag[t] = 1; } dfs1(t); memset(vis, 0, sizeof(vis)); dfs2(t); memset(vis, 0, sizeof(vis)); dfs3(t); memset(vis, 0, sizeof(vis)); dfs4(t, 0); for (int i = 1; i <= n; i++) printf("%lld\n", sum * 2 + mind[i] - d[ner[i]]); return 0; }
bzoj3743 [Coci2015]Kamp 常州模拟赛d6t2
标签:cst amp return 个数 logs ring 多少 情况 font
原文地址:http://www.cnblogs.com/zbtrs/p/7434575.html