Submission #257493

#TimeUsernameProblemLanguageResultExecution timeMemory
257493davooddkareshkiToll (APIO13_toll)C++17
16 / 100
129 ms163844 KiB
#include<bits/stdc++.h> using namespace std; #define int long long #define F first #define S second #define pii pair<int,int> #define mpr make_pair typedef long long ll; const int maxn = 2e5+10; const int mod = 1e9+7; const ll inf = 1e18+10; int n, m, k; struct dsu { int par[maxn]; dsu() {memset(par, -1, sizeof par);} void reset() {fill(par, par+k+3, -1);} int get_par(int v) { if(par[v] < 0) return v; return par[v] = get_par(par[v]); } void add(int u, int v) { u = get_par(u); v = get_par(v); if(u == v) return; if(par[u] < par[v]) swap(u,v); par[v] += par[u]; par[u] = v; } bool ask(int u, int v) {return (get_par(u) == get_par(v));} } dsu; vector<int> T[maxn]; int st[maxn], sz[maxn], comp[maxn], p[maxn], mark[maxn], num; void dfs(int v) { mark[v] = 1; comp[v] = num; sz[num] += p[v]; for(auto u : T[v]) if(!mark[u]) dfs(u); } vector<int> Tree[22]; int pa[maxn], W[maxn], stt[maxn]; void dfs_T(int v) { W[v] = inf; stt[v] = sz[v]; for(auto u : Tree[v]) if(u != pa[v]) { pa[u] = v; dfs_T(u); stt[v] += stt[u]; } } ll ans = 0; void reset() { ans = 0; dsu.reset(); for(int i = 1; i <= k; i++) { Tree[i].clear(); W[i] = inf; pa[i] = 0; stt[i] = 0; } } signed main() { ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0); cin>> n >> m >> k; vector<pair<int,pii>> edge, Bedge; vector<pii> Redge; for(int i = 1, u, v, c; i <= m; i++) { cin>> u >> v >> c; edge.push_back({c,{u,v}}); } sort(edge.begin(), edge.end()); for(int i = 1, u, v; i <= k; i++) { cin>> u >> v; Redge.push_back({u,v}); dsu.add(u,v); } for(auto e : edge) { int u = e.S.F, v = e.S.S, w = e.F; if(!dsu.ask(u,v)) { T[u].push_back(v); T[v].push_back(u); dsu.add(u,v); } else Bedge.push_back(e); } for(int i = 1; i <= n; i++) cin>> p[i]; // comp[Root = 1] = 1 for(int i = 1; i <= n; i++) if(!mark[i]) { num++; dfs(i); } ll last_ans = 0; for(int msk = 0; msk < (1<<k); msk++) { // in k ta dori nabashano ham bayad check koni reset(); bool sw = 0; for(int i = 0; i < k; i++) if((1<<i) & msk) { int u = comp[Redge[i].F], v = comp[Redge[i].S]; int u1 = Redge[i].F, v1 = Redge[i].S; if(dsu.ask(u,v)) sw = 1; dsu.add(u,v); Tree[u].push_back(v); Tree[v].push_back(u); } if(sw) continue; for(auto e : Bedge) { int w = e.F, u = comp[e.S.F], v = comp[e.S.S]; if(!dsu.ask(u,v)) { dsu.add(u,v); Tree[u].push_back(v); Tree[v].push_back(u); } } dfs_T(1); for(auto e : Bedge) { int w = e.F, u = comp[e.S.F], v = comp[e.S.S]; bool seen[k+2]; memset(seen, 0, sizeof seen); while(u != 1) { (seen[u] ^= 1); u = pa[u]; } while(v != 1) { (seen[v] ^= 1); v = pa[v]; } for(int i = 1; i <= k+1; i++) if(seen[i]) W[i] = min(W[i],w); if(u == pa[v]) W[v] = 0; if(v == pa[u]) W[u] = 0; } for(int i = 2; i <= k+1; i++) ans += stt[i] * W[i]; last_ans = max(last_ans, ans); } cout<< last_ans; }

Compilation message (stderr)

toll.cpp: In function 'int main()':
toll.cpp:107:29: warning: unused variable 'w' [-Wunused-variable]
   int u = e.S.F, v = e.S.S, w = e.F;
                             ^
toll.cpp:138:9: warning: unused variable 'u1' [-Wunused-variable]
     int u1 = Redge[i].F, v1 = Redge[i].S;
         ^~
toll.cpp:138:26: warning: unused variable 'v1' [-Wunused-variable]
     int u1 = Redge[i].F, v1 = Redge[i].S;
                          ^~
toll.cpp:149:8: warning: unused variable 'w' [-Wunused-variable]
    int w = e.F, u = comp[e.S.F], v = comp[e.S.S];
        ^
#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...