Submission #583942

#TimeUsernameProblemLanguageResultExecution timeMemory
583942PiejanVDCToy Train (IOI17_train)C++17
0 / 100
8 ms1532 KiB
#include <bits/stdc++.h> #include "train.h" using namespace std; const int mxN = (int)5005; vector<int>adj[mxN]; vector<int>radj[mxN]; vector<int>df; vector<int>c(mxN); int C = 0; vector<bool>vis(mxN); vector<bool>rvis(mxN); void dfs(int u) { vis[u] = 1; for(auto z : adj[u]) if(!vis[z]) { dfs(z); } df.push_back(u); } int cnt; void col(int u) { cnt++; c[u] = C; rvis[u] = 1; for(auto z : radj[u]) if(!rvis[z]) { col(z); } } vector<int>who_wins(vector<int>a, vector<int>r, vector<int>u, vector<int>v) { int n = r.size(); int m = u.size(); for(int i = 0 ; i < m ; i++) { adj[u[i]].push_back(v[i]); radj[v[i]].push_back(u[i]); } dfs(0); vector<bool>valid(n,1); for(auto z : df) { if(c[z]) continue; C++; cnt = 0; col(z); if(cnt == 1) valid[z] = 0; } vector<bool>have(n,0); for(int i = 1 ; i <= C ; i++) { for(int node = 0 ; node < n ; node++) { if(c[node] == i && r[node]) have[i] = 1; } } vector<int>ans(n,0); for(int i = 0 ; i < n ; i++) { vector<bool>t(n,0); t[i] = 1; stack<int>s; s.push(i); while(!s.empty()) { int node = s.top(); s.pop(); if(have[c[node]] && valid[node]) { ans[i] = 1; break; } for(auto z : adj[node]) if(!t[z]) { t[z] = 1; s.push(z); } } } return ans; }
#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...