# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
1103995 | asdfghjk | 콤보 (IOI18_combo) | C++17 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define ll long long
#define pb push_back
#define all(x) x.begin(), x.end()
#define F first
#define ld long double
#define S second
using namespace std;
const ll N = 5e3 + 5;
const ll NN = 4e5 + 5;
const ll INF = 1e18;
const ll inf = 1e9;
const ll MOD = 1e9 + 7;
char a[10];
int was[10];
string z[15];
int press(std::string p);
string find_first(){
string d = "";
d += a[1];
if(press(d) == 1){
a[1] = a[2];
a[2] = a[3];
a[3] = a[4];
return d;
}
d.pop_back();
d += a[2];
if(press(d) == 1){
a[2] = a[3];
a[3] = a[4];
return d;
}
d.pop_back();
d += a[3];
if(press(d) == 1){
a[3] = a[4];
return d;
}
d.pop_back();
d += a[4];
if(press(d) == 1){
return d;
}
}
string guess_sequence(int n){
a[1] = 'A';
a[2] = 'B';
a[3] = 'X';
a[4] = 'Y';
string s = find_first();
for(int i = 2;i <= n;i++){
if(int(s.size()) > i)continue;
string d = s;
d += a[1];
d += a[2];
int res = press(d);
if(res == val){
s += a[3];
}
else if(res == val + 1){
d = s + a[1];
res = press(d);
if(res == val + 1){
s = d;
}
else{
s += a[2];
}
}
else{
s = d;
}
}
return s;
}