This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "train.h"
#include <bits/stdc++.h>
using namespace std;
#define all(x) (x).begin(), (x).end()
#define sep ' '
#define debug(x) cerr << #x << ": " << x << endl;
const int MAXN = 1e6 + 10;
int n, m;
bool A[MAXN], R[MAXN];
vector<int> adj[MAXN];
bool W[MAXN];
vector<int> who_wins(vector<int> a_, vector<int> r_, vector<int> u_, vector<int> v_) {
n = a_.size();
for (int i = 0; i < n; i++)
A[i] = a_[i], R[i] = r_[i];
m = u_.size();
for (int i = 0; i < m; i++)
adj[u_[i]].push_back(v_[i]);
for (int i = n - 1; i >= 0; i--) {
bool f1 = (find(all(adj[i]), i + 1) != adj[i].end());
bool f2 = (find(all(adj[i]), i) != adj[i].end());
if (A[i]) {
if (R[i]) {
if (f2) W[i] = 1;
else W[i] = W[i + 1];
} else {
if (f1) W[i] = W[i + 1];
else W[i] = 0;
}
} else {
if (R[i]) {
if (f1) W[i] = W[i + 1];
else W[i] = 1;
} else {
if (f2) W[i] = 0;
else W[i] = W[i + 1];
}
}
}
vector<int> res;
for (int i = 0; i < n; i++)
res.push_back(W[i]);
return res;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |