Submission #982654

#TimeUsernameProblemLanguageResultExecution timeMemory
982654shenfe1Swapping Cities (APIO20_swap)C++17
13 / 100
225 ms78920 KiB
#include "swap.h" #include <bits/stdc++.h> #pragma optimize("Ofast") #pragma target("avx2") using namespace std; #define ll long long #define ld long double #define pb push_back #define pf push_front #define pii pair<int,int> #define all(v) v.begin(),v.end() #define F first #define S second #define mem(a,i) memset(a,i,sizeof(a)) #define sz(s) (int)s.size() #define y1 yy #define ppb pop_back #define lb lower_bound #define ub upper_bound #define gcd(a,b) __gcd(a,b) #define in insert const int MAX=1e6+15; const int B=300; const int N=104; const int block=400; const int maxB=MAX/B+10; const ll inf=2e9; const int mod=998244353; const int mod1=1e9+9; const ld eps=1e-9; int dx[8]={1,0,-1,0,1,-1,-1,1}; int dy[8]={0,1,0,-1,1,-1,1,-1}; int binpow(int a,int n){ if(!n)return 1; if(n%2==1)return a*binpow(a,n-1)%mod; int k=binpow(a,n/2); return k*k%mod; } mt19937 rng(chrono::steady_clock::now().time_since_epoch().count()); int n; int mark[MAX]; int cost[MAX]; vector<int> g[MAX]; struct DSU{ int f[MAX]; int cur; void init(int n,int ver){ cur=ver; for(int i=1;i<=n;i++)f[i]=i; } int get(int v){ return f[v]==v?v:f[v]=get(f[v]); } void unite(int a,int b,bool is,int C){ a=get(a); b=get(b); int x=++cur; g[x].pb(a); g[x].pb(b); // cout<<x<<" "<<a<<"\n"; // cout<<x<<" "<<b<<"\n"; mark[x]=is; cost[x]=C; f[a]=f[b]=x; } void cycle(int a,int C){ a=get(a); int x=++cur; cost[x]=C; g[x].pb(a); // cout<<x<<" "<<a<<"\n"; mark[x]=1; f[a]=x; } }D; int up[MAX][20]; int tin[MAX],tout[MAX],timer; int mn[MAX]; int deg[MAX]; void dfs(int v,int p){ tin[v]=++timer; up[v][0]=p; // cout<<v<<" "<<p<<"\n"; for(int i=1;i<20;i++)up[v][i]=up[up[v][i-1]][i-1]; if(mark[v]){ mn[v]=cost[v]; } for(auto to:g[v]){ if(to==p)continue; mn[to]=mn[v]; // cout<<v<<" -> "<<to<<"\n"; dfs(to,v); } tout[v]=timer; } void dfs1(int v,int p){ for(auto to:g[v]){ if(to==p)continue; dfs1(to,v); mn[v]=min(mn[v],mn[to]); } } void init(int N, int M,vector<int> U,vector<int> V,vector<int> W) { D.init(N+M,N); vector<pair<int,pii>> e; for(int i=0;i<M;i++){ U[i]++;V[i]++; e.pb({W[i],{U[i],V[i]}}); } sort(all(e)); for(auto x:e){ int w=x.F; int u=x.S.F; int v=x.S.S; // cerr<<w<<" "<<u<<" "<<v<<"\n"; if(D.get(u)!=D.get(v)){ deg[u]++; deg[v]++; bool is=(deg[u]==3||deg[v]==3); D.unite(u,v,is,w); // if(is)D.cycle(u,w); } else{ D.cycle(u,w); } } // cerr<<1<<"\n"; for(int i=1;i<=D.cur;i++){ if(!mark[i])mn[i]=inf; else mn[i]=cost[i]; } dfs1(D.get(1),D.get(1)); dfs(D.get(1),D.get(1)); // for(int i=1;i<=D.cur;i++)cout<<i<<" "<<mn[i]<<" "<<mark[i]<<" "<<cost[i]<<"\n"; } int par(int a,int b){ return (tin[a]<=tin[b]&&tout[b]<=tout[a]); } int lca(int a,int b){ if(par(a,b))return a; if(par(b,a))return b; for(int i=19;i>=0;i--){ if(!par(up[a][i],b)){ a=up[a][i]; } } return up[a][0]; } int getMinimumFuelCapacity(int X, int Y) { X++; Y++; // cout<<lca(X,Y)<<" "<<up[X][19]<<"\n"; // cout<<cost[lca(X,Y)]<<" "<<mn[X]<<" "<<mn[Y]<<"\n"; if(max(max(mn[X],mn[Y]),cost[lca(X,Y)])==inf)return -1; return max(max(mn[X],mn[Y]),cost[lca(X,Y)]); }

Compilation message (stderr)

swap.cpp:4: warning: ignoring '#pragma optimize ' [-Wunknown-pragmas]
    4 | #pragma optimize("Ofast")
      | 
swap.cpp:5: warning: ignoring '#pragma target ' [-Wunknown-pragmas]
    5 | #pragma target("avx2")
      |
#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...