제출 #219994

#제출 시각아이디문제언어결과실행 시간메모리
219994BasilhijazCombo (IOI18_combo)C++14
5 / 100
1 ms200 KiB
#include <combo.h>

using namespace std;

string guess_sequence(int N) {
    string p = "";
    string ans = "";
    string opt = "ABXY";
    int pos = -1;
    for(int i = 0; i < 3; i++){
        p = "";
        p += opt[i];
        if(press(p) == 1){
            ans += p;
            pos = i;
            break;
        }
    }
    if(pos == -1){
        pos = 3;
        ans += opt[3];
    }
    string Fopt = "";
    for(int i = 0; i < 4; i++){
        if(i == pos)continue;
        Fopt += opt[i];
    }
    for(int i = 0; i < N - 2; i++){
        p = "";
        p += ans; p += Fopt[0]; p += ans; p += Fopt[1]; p += Fopt[1];
        p += ans; p += Fopt[1]; p += Fopt[0]; p += ans; p += Fopt[1]; p += Fopt[2];
        int num = press(p);
        if(num == i + 1){
            ans += Fopt[2];
        }
        else if(num == i + 2){
            ans += Fopt[0];
        }
        else{
            ans += Fopt[1];
        }
    }
    bool ok = 1;
    for(int i = 0; i < 2; i++){
        p = "";
        p += ans; p += Fopt[i];
        if(press(p) == N){
            ans += Fopt[i];
            ok = 0;
            break;
        }
    }
    if(ok){
        ans += Fopt[2];
    }
    return ans;
}

#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...