이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "cave.h"
#define MAXN 5005
#define lp(i,a,b) for(int i = a ; i < b ; i++)
#define pb push_back
#define pii pair<int,int>
#define ff first
#define ss second
using namespace std;
int N ;
int A[MAXN] , B[MAXN] , s[MAXN];
int resp1[MAXN] , resp2[MAXN] ;
pii ans[MAXN] ;
int findDoor( int door )
{
memset(s , 0 , sizeof s) ;
lp(i,0,N)
if( A[i] != -1 ) s[ A[i] ] = B[i] ;
int k = tryCombination(s) ;
if(k == -1) k = door + 1 ;
if( k > door ) return B[door] = 0 ;
else return B[door] = 1 ;
}
int findSwitch( int door )
{
int u = 0 , l = N-1 , mid ;
int x = B[door] ;
while( u < l )
{
mid = (u+l)/2 ;
memset(s , -1 , sizeof s) ;
lp(i,0,N)
if(A[i] != -1) s[ A[i] ] = B[ i ] ;
lp(i,u,mid+1)
if(s[i] == -1 ) s[i] = x ;
lp(i,mid+1 , l+1)
if( s[i] == -1 ) s[i] = !x ;
int k = tryCombination(s) ;
if( k == -1 ) k = door + 1 ;
if(k > door) l = mid ;
else u = mid + 1 ;
}
return l ;
}
void exploreCave( int n )
{
//
N = n ;
memset(A, -1 , sizeof A) ;
memset(B, -1, sizeof B) ;
//
lp(i,0,N)
{
B[i] = findDoor(i) ;
A[i] = findSwitch(i) ;
}
pii p[MAXN] ;
lp(i,0,N) p[i] = pii( A[i] , i ) ;
sort(p,p+N) ;
lp(i,0,N) resp1[i] = p[i].ss ;
lp(i,0,N) resp2[i] = B[ p[i].ss ] ;
answer(resp1, resp2) ;
}
# | 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... |