Submission #113824

#TimeUsernameProblemLanguageResultExecution timeMemory
113824faustaadpToy Train (IOI17_train)C++17
5 / 100
2076 ms199772 KiB
#include "train.h" #include<bits/stdc++.h> typedef long long ll; #define pb push_back #define mp make_pair #define fi first #define se second using namespace std; ll m,n,a[5050],b[5050],cic[5050],nx[5050],i,TC1,putar[5050],x[5050][5050],j; vector<ll> v[5050]; ll cek(ll aa) { if(a[aa]==1) { if(b[aa]&&cic[aa]) return 1; if(nx[aa]) return cek(aa+1); return 0; } else { if(b[aa]==0&&cic[aa]) return 0; if(nx[aa]) return cek(aa+1); return 1; } } void dfs(ll aa,ll bb) { ll ii; for(ii=0;ii<v[bb].size();ii++) if(!x[aa][v[bb][ii]]) { x[aa][v[bb][ii]]=1; dfs(aa,v[bb][ii]); } } std::vector<int> who_wins(std::vector<int> A, std::vector<int> r, std::vector<int> U, std::vector<int> V) { m=U.size(); n=A.size(); for(i=0;i<n;i++)a[i]=A[i]; for(i=0;i<n;i++)b[i]=r[i]; TC1=1; for(i=0;i<m;i++) { if(U[i]==V[i]) cic[U[i]]=1; else if(U[i]+1==V[i]) nx[U[i]]=1; else TC1=0; v[U[i]].pb(V[i]); v[V[i]].pb(U[i]); } std::vector<int> res(n); if(TC1) { for(int i = 0; i < n; i++) res[i] = cek(i); } else { for(i=0;i<n;i++) dfs(i,i); for(i=0;i<n;i++) for(j=0;j<n;j++) if(x[i][j]&&x[j][i]&&b[i]) putar[i]=1; for(i=0;i<n;i++) res[i]=0; for(i=0;i<n;i++) for(j=0;j<n;j++) if(x[i][j]&&putar[j]) res[i]=1; } return res; }

Compilation message (stderr)

train.cpp: In function 'void dfs(ll, ll)':
train.cpp:33:13: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(ii=0;ii<v[bb].size();ii++)
           ~~^~~~~~~~~~~~~
#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...