#include "game.h"
#include <bits/stdc++.h>
#define sz(a) (int)a.size()
#define all(a) a.begin(), a.end()
#define rall(a) a.rbegin(), a.rend()
using namespace std;
vector<vector<int>> edge;
vector<vector<int>> invedge;
vector<bool> r;
vector<bool> s;
int n,k;
void init(int _n, int _k) {
n=_n;
k=_k;
edge.resize(n);
invedge.resize(n);
r.resize(n);
s.resize(n);
for (int i = 0; i < k-1; i++)
{
edge[i].push_back(i+1);
invedge[i+1].push_back(i);
r[i+1]=true;
s[i]=true;
}
}
bool rdfs(int x){
if(s[x]) return true;
if(r[x]) return false;
r[x]=true;
for (auto u : edge[x])
if(rdfs(u)) return true;
return false;
}
bool sdfs(int x){
if(r[x]) return true;
if(s[x]) return false;
s[x]=true;
for (auto u : invedge[x])
if(sdfs(u)) return true;
return false;
}
int add_teleporter(int u, int v) {
bool b=false;
edge[u].push_back(v);
invedge[v].push_back(u);
if((r[u]||u<k)&&rdfs(v)) b=true;
if((s[v]||v<k)&&sdfs(u)) b=true;
return (int)b;
}
# | 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... |