제출 #978178

#제출 시각아이디문제언어결과실행 시간메모리
978178LOLOLOTraffic (IOI10_traffic)C++14
100 / 100
1006 ms202096 KiB
#include <bits/stdc++.h> #define ll long long using namespace std; #define f first #define s second #define pb push_back #define ep emplace #define eb emplace_back #define lb lower_bound #define ub upper_bound #define all(x) x.begin(), x.end() #define rall(x) x.rbegin(), x.rend() #define uniquev(v) sort(all(v)), (v).resize(unique(all(v)) - (v).begin()) #define mem(f,x) memset(f , x , sizeof(f)) #define sz(x) (int)(x).size() #define __lcm(a, b) (1ll * ((a) / __gcd((a), (b))) * (b)) #define mxx *max_element #define mnn *min_element #define cntbit(x) __builtin_popcountll(x) #define len(x) (int)(x.length()) const int N = 1e6 + 10; vector <int> ed[N]; ll f[N], a[N], sum[N]; void dfs(int u, int v) { sum[u] = a[u]; if (u != v) { auto it = find(all(ed[u]), v); ed[u].erase(it); } for (auto x : ed[u]) { dfs(x, u); sum[u] += sum[x]; f[u] = max(f[u], sum[x]); } } //before -> u is v's parent void reroot(int u, int v) { sum[u] -= sum[v]; sum[v] += sum[u]; f[v] = max(f[v], sum[u]); } ll ans = 1e18, id = 0; void dfs2(int u) { if (ans > f[u]) { ans = f[u]; id = u; } sort(all(ed[u]), [&] (int x, int y) {return sum[x] > sum[y];}); for (int i = 0; i < sz(ed[u]); i++) { int x = ed[u][i]; ll p1 = f[u], p2 = f[x]; if (sz(ed[u]) == 1) { f[u] = 0; } else { if (i == 0) { f[u] = sum[ed[u][1]]; } else { f[u] = sum[ed[u][0]]; } } reroot(u, x); dfs2(x); sum[x] -= sum[u]; sum[u] += sum[x]; f[u] = p1, f[x] = p2; } } int LocateCentre(int n, int P[], int S[], int D[]) { ans = 1e18; for (int i = 0; i < n - 1; i++) { ed[S[i]].pb(D[i]); ed[D[i]].pb(S[i]); } for (int i = 0; i < n; i++) a[i] = P[i]; dfs(0, 0); dfs2(0); return id; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...