# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
534541 | YaserFaisal | 콤보 (IOI18_combo) | C++17 | 28 ms | 504 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "combo.h"
using namespace std;
string call( string cur , int siz , int n )
{
int x , y ;
if ( siz == n-1 )
{
if ( cur[0] == 'A' )
{
x = press(cur+'B') ;
y = press(cur+'X') ;
if ( x == n ) return cur+'B' ;
else if ( y == n ) return cur+'X' ;
else return cur+'Y' ;
}
if ( cur[0] == 'B' )
{
x = press(cur+'A') ;
y = press(cur+'X') ;
if ( x == n ) return cur+'A' ;
else if ( y == n ) return cur+'X' ;
else return cur+'Y' ;
}
if ( cur[0] == 'X' )
{
x = press(cur+'B') ;
y = press(cur+'A') ;
if ( x == n ) return cur+'B' ;
else if ( y == n ) return cur+'A' ;
else return cur+'Y' ;
}
if ( cur[0] == 'Y' )
{
x = press(cur+'B') ;
y = press(cur+'X') ;
if ( x == n ) return cur+'B' ;
else if ( y == n ) return cur+'X' ;
else return cur+'A' ;
}
}
if ( cur[0] == 'A' )
{
x = press(cur+'B'+cur+"XX"+cur+"XY"+cur+"XB") ;
if ( x == siz+1 ) return cur+'B' ;
else if ( x == siz+2 ) return cur+'X' ;
else return cur+'Y' ;
}
if ( cur[0] == 'B' )
{
x = press(cur+'A'+cur+"XX"+cur+"XY"+cur+"XA") ;
if ( x == siz+1 ) return cur+'A' ;
else if ( x == siz+2 ) return cur+'X' ;
else return cur+'Y' ;
}
if ( cur[0] == 'X' )
{
x = press(cur+'B'+cur+"AX"+cur+"AY"+cur+"AB") ;
if ( x == siz+1 ) return cur+'B' ;
else if ( x == siz+2 ) return cur+'A' ;
else return cur+'Y' ;
}
if ( cur[0] == 'Y' )
{
x = press(cur+'B'+cur+"XX"+cur+"XY"+cur+"XB") ;
if ( x == siz+1 ) return cur+'B' ;
else if ( x == siz+2 ) return cur+'X' ;
else return cur+'A' ;
}
}
string call2( string cur )
{
int siz = cur.size()+1 ;
if ( cur[0] == 'A' )
{
if ( press(cur+'B') == siz ) return cur+'B' ;
else if ( press(cur+'X') == siz ) return cur+'X' ;
else return cur+'Y' ;
}
if ( cur[0] == 'B' )
{
if ( press(cur+'A') == siz ) return cur+'A' ;
else if ( press(cur+'X') == siz ) return cur+'X' ;
else return cur+'Y' ;
}
if ( cur[0] == 'X' )
{
if ( press(cur+'B') == siz ) return cur+'B' ;
else if ( press(cur+'A') == siz ) return cur+'A' ;
else return cur+'Y' ;
}
if ( cur[0] == 'Y' )
{
if ( press(cur+'B') == siz ) return cur+'B' ;
else if ( press(cur+'X') == siz ) return cur+'X' ;
else return cur+'A' ;
}
}
string guess_sequence (int n)
{
for ( int i = 0 ; i <= 2000 ; i++ )
{
}
string cur = "" ;
int x = press("AB") ;
if ( x == 0 )
{
if ( press(cur+'X') == 1 ) cur+='X' ;
else cur+='Y' ;
}
else
{
if ( press(cur+'A') == 1 ) cur+='A' ;
else cur+='B' ;
}
if( n > 5 ) while(cur.size()<n) cur = call(cur,cur.size(),n) ;
else while(cur.size()<n) cur = call2(cur) ;
return cur ;
}
컴파일 시 표준 에러 (stderr) 메시지
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |