Submission #734737

#TimeUsernameProblemLanguageResultExecution timeMemory
734737SanguineChameleonToll (APIO13_toll)C++17
56 / 100
2557 ms20504 KiB
#include <bits/stdc++.h> using namespace std; void just_do_it(); int main() { #ifdef KAMIRULEZ freopen("kamirulez.inp", "r", stdin); freopen("kamirulez.out", "w", stdout); #endif ios_base::sync_with_stdio(0); cin.tie(0); just_do_it(); return 0; } struct edge { int u, v, w; }; bool operator<(edge E1, edge E2) { return E1.w < E2.w; }; const int inf = 1e9 + 20; const int maxN = 1e5 + 20; const int maxM = 3e5 + 20; const int maxK = 25; int a[maxN]; vector<pair<int, int>> adj[maxN]; long long cnt[maxN]; int par[maxN]; int mi[maxN]; int depth[maxN]; edge edges[maxM]; int N, M, K; int root(int u) { if (!par[u]) { return u; } return (par[u] = root(par[u])); } bool update(int u, int v) { int ru = root(u); int rv = root(v); if (ru == rv) { return false; } if (depth[ru] > depth[rv]) { swap(ru, rv); } par[ru] = rv; if (depth[ru] == depth[rv]) { depth[rv]++; } return true; } long long sum; void dfs1(int u, int p) { for (auto e: adj[u]) { int v = e.first; if (v == p) { continue; } par[v] = u; depth[v] = depth[u] + 1; dfs1(v, u); } } void dfs2(int u, int p) { cnt[u] = a[u]; for (auto e: adj[u]) { int v = e.first; int id = e.second; if (v == p) { continue; } dfs2(v, u); if (id >= M) { sum += cnt[v] * mi[v]; } cnt[u] += cnt[v]; } } void update(int u, int v, int w) { if (depth[u] < depth[v]) { swap(u, v); } while (depth[u] != depth[v]) { mi[u] = min(mi[u], w); u = par[u]; } while (u != v) { mi[u] = min(mi[u], w); mi[v] = min(mi[v], w); u = par[u]; v = par[v]; } } long long solve(int h) { for (int i = 1; i <= N; i++) { par[i] = 0; depth[i] = 0; adj[i].clear(); mi[i] = inf; } for (int i = 0; i < K; i++) { if ((h >> i) & 1) { int u = edges[M + i].u; int v = edges[M + i].v; if (update(u, v)) { adj[u].emplace_back(v, M + i); adj[v].emplace_back(u, M + i); } else { return -1; } } } vector<int> extra; for (int i = 0; i < M; i++) { int u = edges[i].u; int v = edges[i].v; if (update(u, v)) { adj[u].emplace_back(v, i); adj[v].emplace_back(u, i); } else { extra.emplace_back(i); } } depth[1] = 0; dfs1(1, -1); for (auto i: extra) { int u = edges[i].u; int v = edges[i].v; int w = edges[i].w; update(u, v, w); } sum = 0; dfs2(1, -1); return sum; } void just_do_it() { cin >> N >> M >> K; for (int i = 0; i < M; i++) { cin >> edges[i].u >> edges[i].v >> edges[i].w; } for (int i = M; i < M + K; i++) { cin >> edges[i].u >> edges[i].v; edges[i].w = 0; } for (int i = 1; i <= N; i++) { cin >> a[i]; } sort(edges, edges + M); long long res = 0; for (int h = 0; h < (1 << K); h++) { res = max(res, solve(h)); } cout << res; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...