Submission #130620

#TimeUsernameProblemLanguageResultExecution timeMemory
130620abacabaFactories (JOI14_factories)C++14
0 / 100
8103 ms126316 KiB
#include "factories.h" #include <bits/stdc++.h> using namespace std; #define pb push_back #define ll long long const int l = 21; const ll inf = 2e15; const int MAX_N = 5e5 + 15; const int MAX_Q = 1e6 + 15; const int MAX_SUM_ST = 1e6 + 15; const int MAX_VALUE = 1e9; int n, m, sz[MAX_N], up[MAX_N][l], tin[MAX_N], tout[MAX_N], last; ll minn[MAX_N]; vector <int> g[MAX_N], d[MAX_N]; int pCentroid[MAX_N]; ll dist[MAX_N]; bool deleted[MAX_N]; void start(int v, int p) { tin[v] = ++last; up[v][0] = p; for(int i = 1; i < l; ++i) up[v][i] = up[up[v][i-1]][i-1]; for(int i = 0; i < g[v].size(); ++i) if(g[v][i] != p) { dist[g[v][i]] = dist[v] + d[v][i]; start(g[v][i], v); } tout[v] = ++last; } bool upper(int a, int b) { return tin[a] <= tin[b] && tout[a] >= tout[b]; } int lca(int a, int b) { if(upper(a, b)) return a; if(upper(b, a)) return b; for(int i = l - 1; i >= 0; --i) if(!upper(up[a][i], b)) a = up[a][i]; return up[a][0]; } void build(int v, int p = -1) { sz[v] = 1; for(auto to : g[v]) if(to != p && !deleted[to]) { build(to, v); sz[v] += sz[to]; } } int centroid(int v, int p, int n) { for(auto to : g[v]) if(!deleted[to] && to != p && sz[to] > n / 2) return centroid(to, v, n); return v; } void dfs(int v, int p, int center) { pCentroid[v] = center; for(int i = 0; i < g[v].size(); ++i) { int to = g[v][i]; if(!deleted[to] && to != p) dfs(to, v, center); } } void process(int center) { deleted[center] = true; build(center, -1); for(int to : g[center]) if(!deleted[to]) dfs(to, -1, center); for(int to : g[center]) if(!deleted[to]) process(centroid(to, -1, sz[to])); } ll distance(int u, int v) { return dist[u] + dist[v] - 2 * dist[lca(u, v)]; } void Init(int N, int A[], int B[], int D[]) { n = N; for(int i = 0; i < n; ++i) { ++A[i]; ++B[i]; g[A[i]].pb(B[i]); d[A[i]].pb(D[i]); g[B[i]].pb(A[i]); d[B[i]].pb(D[i]); } fill(minn, minn + MAX_N, inf); fill(pCentroid, pCentroid + MAX_N, -1); start(1, 1); build(1); process(centroid(1, -1, n)); } long long Query(int S, int X[], int T, int Y[]) { ll ans = inf; for(int i = 0; i < S; ++i) ++X[i]; for(int i = 0; i < T; ++i) ++Y[i]; for(int i = 0; i < S; ++i) { int v = X[i]; minn[X[i]] = 0; int cnt = 0; while(v != -1) { ++cnt; if(pCentroid[v] != -1) minn[pCentroid[v]] = min(minn[pCentroid[v]], distance(pCentroid[v], X[i])); v = pCentroid[v]; } assert(cnt <= 50); } for(int i = 0; i < T; ++i) { int v = Y[i]; int cnt = 0; while(v != -1) { ++cnt; ans = min(ans, distance(v, Y[i]) + minn[v]); v = pCentroid[v]; } assert(cnt <= 50); } for(int i = 0; i < S; ++i) { int v = X[i]; minn[X[i]] = inf; while(v != -1) { minn[v] = inf; v = pCentroid[v]; } } return ans; }

Compilation message (stderr)

factories.cpp: In function 'void start(int, int)':
factories.cpp:27:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(int i = 0; i < g[v].size(); ++i)
                 ~~^~~~~~~~~~~~~
factories.cpp: In function 'void dfs(int, int, int)':
factories.cpp:68:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(int i = 0; i < g[v].size(); ++i) {
                 ~~^~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...