#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 time |
Memory |
Grader output |
1 |
Incorrect |
6 ms |
1236 KB |
3rd lines differ - on the 1st token, expected: '0', found: '1' |
2 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Incorrect |
1 ms |
468 KB |
3rd lines differ - on the 1st token, expected: '0', found: '1' |
2 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Incorrect |
6 ms |
1492 KB |
3rd lines differ - on the 1st token, expected: '0', found: '1' |
2 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Incorrect |
7 ms |
1236 KB |
3rd lines differ - on the 696th token, expected: '0', found: '1' |
2 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Incorrect |
8 ms |
1532 KB |
3rd lines differ - on the 2nd token, expected: '0', found: '1' |
2 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Incorrect |
6 ms |
1236 KB |
3rd lines differ - on the 1st token, expected: '0', found: '1' |
2 |
Halted |
0 ms |
0 KB |
- |