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 "coprobber.h"
#include <bits/stdc++.h>
#define sz(x) (int)(x.size() )
#define all(x) x.begin(),x.end()
#define debug printf
#define ll long long
const int MAXN = 510 ;
using namespace std ;
int nxtMove[MAXN][MAXN] ;
int outDeg[MAXN][MAXN][2] ;
bool graph[MAXN][MAXN] ;
bool isWinner[MAXN][MAXN][2] ;
int myCurrent , n ;
int start(int N, bool A[MAX_N][MAX_N])
{
n = N ;
for(int i = 0 ; i < N ; i++ )
for(int j = 0 ; j < N ; j++ )
graph[i][j] = A[i][j] ;
for(int i = 0 ; i < N ; i++ )
for(int j = 0 ; j < N ; j++ )
for(int k = 0 ; k < 2 ; k++ )
{
isWinner[i][j][k] = k ? true : false ;
if( i == j && k == 1 ) continue ;
if(!k)
{
for(int g = 0 ; g < N ; g++ )
if( A[i][g] ) outDeg[i][j][k]++ ;
outDeg[i][j][k]++ ;
}
else
{
for(int g = 0 ; g < N ; g++ )
if( A[j][g] ) outDeg[i][j][k]++ ;
}
}
vector< tuple<int,int,int> > q ;
int ini = 0 ;
for(int i = 0 ; i < N ; i++ )
for(int j = 0 ; j < N ; j++ )
for(int k = 0 ; k < 2 ; k++ )
if( outDeg[i][j][k] == 0 ) q.push_back( make_tuple(i,j,k) ) ;
while( ini < sz(q) )
{
int x = get<0>( q[ini] ) ;
int y = get<1>( q[ini] ) ;
int z = get<2>( q[ini] ) ;
ini++ ;
isWinner[x][y][z] = z ? false : true ;
//cout << x << " " << y << " " << z << endl ;
if(!z)
{
//I'm the cop's turn
//That means my previous must be a robber's move
for(int i = 0 ; i < N ; i++ )
if( A[i][y] && (--outDeg[x][i][1]) == 0 ) q.push_back( make_tuple(x,i,1) ) ;
}
else
{
for(int i = 0 ; i < N ; i++ )
{
if( !A[i][x] && i != x ) continue ;
if( outDeg[i][y][0] <= 0 ) continue ;
outDeg[i][y][0] = 0 ;
nxtMove[i][y] = x ;
q.push_back( make_tuple(i,y,0) ) ;
}
}
}
for(int i = 0 ; i < N ; i++ )
{
bool theyWin = true ;
for(int j = 0 ; j < N ; j++ )
theyWin &= isWinner[i][j][0] ;
if( theyWin ) return myCurrent = i ;
}
return -1 ;
}
int nextMove(int R)
{
//The state is (myCurrent, R, 0)
return myCurrent = nxtMove[myCurrent][R] ;
}
# | 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... |