이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
#include "dreaming.h"
using namespace std;
typedef long long ll;
typedef pair < ll , ll > pll;
vector < vector < pll > > g;
vector < bool > vis;
vector < pll > b;
ll d = 0;
ll dfs1(ll x, ll pa=-1)
{
vis[x] = true;
b[x] = {0, 0};
for (auto [y, w] : g[x]) if (y != pa)
{
ll temp = dfs1(y, x) + w;
if (b[x].second < temp) b[x].second = temp;
if (b[x].first < b[x].second) swap(b[x].first, b[x].second);
}
return b[x].first;
}
ll dfs2(ll x, ll w = 0, ll pa=-1)
{
if (pa != -1)
{
ll up = b[pa].first;
if (up == b[x].first + w) up = b[pa].second;
up += w;
if (up > b[x].second) b[x].second = up;
if (b[x].second > b[x].first) swap(b[x].second, b[x].first);
}
ll bes = b[x].first;
d = max(d, b[x].first + b[x].second);
for (auto [y, w] : g[x]) if (y != pa)
{
bes = min(bes, dfs2(y, w, x));
}
return bes;
}
ll calc(ll x)
{
dfs1(x);
return dfs2(x);
}
int travelTime(int N, int M, int L, int A[], int B[], int T[])
{
g.resize(N);
vis.resize(N, false);
b.resize(N, {0, 0});
for (ll i = 0; i < M; i++)
{
g[A[i]].push_back({B[i], T[i]});
g[B[i]].push_back({A[i], T[i]});
}
ll g1=-1, g2=-1, g3=-1;
for (ll x = 0; x < N; x++) if (!vis[x])
{
ll temp = calc(x);
if (temp > g1)
{
g3 = g2;
g2 = g1;
g1 = temp;
}
else if (temp > g2)
{
g3 = g2;
g2 = temp;
}
else if (temp > g3)
{
g3 = temp;
}
}
ll ans = d;
if (g2 != -1)
{
ans = max(ans, g1 + g2 + L);
}
if (g3 != -1)
{
ans = max(ans, g2 + g3 + L + L);
}
return ans;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |