noi.ac #241 distance
Posted 11haonb
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了noi.ac #241 distance相关的知识,希望对你有一定的参考价值。
话说这noi.ac是为了给蒟蒻增强信心还是干啥,这比赛后面几题搞的有点水啊。。
虽然第一题比较毒。。
这T3。。。水的一批。。。
直接先预处理一下每个点为根的到其他点的距离不就行了吗?
算了不说了。。。
直接给代码。。。
#include <bits/stdc++.h>
#define ll long long
using namespace std;
const ll N = 10010;
ll head[N], Next[N<<1], ver[N<<1], edge[N], tot = 1;
ll Min(ll x, ll y)
return x < y ? x : y;
ll Max(ll x, ll y)
return x > y ? x : y;
template<class I>
inline void rd(I &x)
ll f = 1;
char c = getchar();
for(; c < '0' || c > '9'; c = getchar()) if(c == '-') f = -1;
for(x = 0; c >= '0' && c <= '9'; x = (x << 3) + (x << 1) + (c & 15), c = getchar());
x *= f;
ll dist[N][N];
void dfs(ll root, ll x, ll fa, ll dep)
dist[root][x] = dep;
for (ll i = head[x]; i; i = Next[i])
ll y = ver[i];
if(y == fa) continue;
dfs(root,y,x,dep + edge[i]);
void add(ll x, ll y, ll z)
ver[++tot] = y;
Next[tot] = head[x];
head[x] = tot;
edge[tot] = z;
ll n, q;
ll ans = 0;
int main()
rd(n), rd(q);
for (ll i = 1; i < n; i++)
ll x, y, z;
rd(x), rd(y), rd(z);
add(x,y,z);
add(y,x,z);
for (ll root = 1; root <= n; root++)
dfs(root, root, 0, 0);
while(q--)
ans = 0;
ll x, y;
rd(x), rd(y);
for (ll i = 1; i <= n; i++)
ans = Max(ans, Min(dist[x][i], dist[y][i]));
printf("%lld\n",ans);
return 0;
以上是关于noi.ac #241 distance的主要内容,如果未能解决你的问题,请参考以下文章