Submission #949857

#TimeUsernameProblemLanguageResultExecution timeMemory
949857KiaRezSwapping Cities (APIO20_swap)C++17
6 / 100
246 ms69108 KiB
/* IN THE NAME OF GOD */ #include <bits/stdc++.h> // #pragma GCC target("avx2,bmi,bmi2,lzcnt,popcnt") // #pragma GCC optimize("O3") // #pragma GCC optimize("unroll-loops") using namespace std; typedef long long ll; typedef pair<ll, ll> pll; typedef pair<int, int> pii; typedef long double ld; #define F first #define S second #define Mp make_pair #define pb push_back #define pf push_front #define size(x) ((ll)x.size()) #define all(x) (x).begin(),(x).end() #define kill(x) cout << x << '\n', exit(0); #define fuck(x) cout << "(" << #x << " , " << x << ")" << endl #define endl '\n' const int N = 5e5+23, lg = 20; ll Mod = 1e9+7; //998244353; inline ll MOD(ll a, ll mod=Mod) {a%=mod; (a<0)&&(a+=mod); return a;} inline ll poww(ll a, ll b, ll mod=Mod) { ll ans = 1; a=MOD(a, mod); while (b) { if (b & 1) ans = MOD(ans*a, mod); b >>= 1; a = MOD(a*a, mod); } return ans; } int n, m, h[N], ok[N], cnt, cnd[N], f[N], par[lg][N], mx[N]; vector<pii> e; vector<int> tree[N]; int getPar(int v) {return (f[v]==0 ? v : f[v]=getPar(f[v]));} void merge(int v, int u, int w) { v=getPar(v), u=getPar(u); if(v == u) { ok[v] = 1, mx[cnd[v]] = min(mx[cnd[v]], w); return; } tree[cnt].pb(cnd[v]); tree[cnt].pb(cnd[u]); ok[v] |= ok[u]; if(ok[v] == 1) mx[cnt] = w; cnd[v] = cnt; cnt++; f[u] = v; } void dfs_init(int v, int p=0) { h[v] = h[p] + 1, par[0][v] = (p==0 ? v : p); mx[v] = min(mx[v], mx[p]); for(int i=1; i<lg; i++) { par[i][v] = par[i-1][par[i-1][v]]; } for(auto u : tree[v]) { if(u == p) continue; dfs_init(u, v); } } int getF(int v, int dist) { for(int i=0; i<lg; i++) if((dist>>i)%2 == 1) { v = par[i][v]; } return v; } int LCA(int v, int u) { if(h[v] > h[u]) swap(v, u); u = getF(u, h[u]-h[v]); if(v == u) return v; for(int i=lg-1; i>=0; i--) { if(par[i][v] != par[i][u]) v=par[i][v], u=par[i][u]; } return par[0][v]; } void init(int _n, int _m, vector<int> V, vector<int> U, vector<int> W) { n=_n, m=_m, cnt=_n+1; for(int i=0; i<m; i++) { V[i]++, U[i]++; e.pb({W[i], i}); } fill(mx, mx+N, (int)2e9); for(int i=0; i<N; i++) cnd[i] = i; sort(all(e)); for(auto it : e) { merge(V[it.S], U[it.S], it.F); } dfs_init(cnd[getPar(1)]); } int getMinimumFuelCapacity(int v, int u) { v++, u++; int lca = LCA(v, u); if(mx[lca] == 2e9) return -1; return mx[lca]; } /* int main() { init(5, 6, {0, 0, 1, 1, 1, 2}, {1, 2, 2, 3, 4, 3}, {4, 4, 1, 2, 10, 3}); cout<<getMinimumFuelCapacity(1, 2)<<endl; cout<<getMinimumFuelCapacity(2, 4)<<endl; cout<<getMinimumFuelCapacity(0, 1)<<endl; init(3, 2, {0, 0}, {1, 2}, {5, 5}); cout<<getMinimumFuelCapacity(1, 2)<<endl; return 0; } */
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...