Submission #1122375

#TimeUsernameProblemLanguageResultExecution timeMemory
1122375khomeCombo (IOI18_combo)C++17
5 / 100
1 ms336 KiB



#include <bits/stdc++.h>
#include "combo.h"
 
using namespace std;
 
string guess_sequence(int N) {
    vector<char> a;
    a={'X', 'Y', 'A', 'B'};
    string res, cur;
    int ab = press("AB"), bx = press("BX"), id=2;
    if (ab == 2) {
        id = 2;
        res = "AB";
    }
    if (ab == 1) {
        if (bx == 1) { //BX = 1;
            id=3;
            int by = press("BY"); 
            if (by == 2) res = "BY";
            else res = "BA";
        } 
        if (bx == 2) {
            id = 3;
            res += "BX";
        }
        if (bx == 0) { // BX = 0; AY, AX
            id = 2;
            int ay = press("AY");
            if (ay == 2) res = "AY";
            else res = "AX";
        }
    }
    else if (ab == 0) {
        if (bx == 1) { // XA, XB, XY
            id = 0;
            int xa = press("XAAXABXAYXB");
            if (xa == 3) res = "XA";
            else if (xa == 2) res = "XB";
            else res = "XY";
        }
        else { // YA, YB, YX
            id = 1;
            int yb = press("YAAYABYAXYB");
            if (yb == 3) res = "YA";
            else if (yb == 2) res = "YB";
            else res = "YX";
        }
    }
    
    int n = res.size();
    if (N==3){
        int x = press(res+a[(id+1)%4]), y = press(res+a[(id+2)%4]);
        if (x == 3)  res+=a[(id+1)%4];  
        else if (y == 3) res+=a[(id+2)%4];  
        else res+=a[(id+3)%4];  
    }
    else{
        char c = a[(id+1)%4], d = a[(id+2)%4], e = a[(id+3)%4];
        int ask;
        while (n<N-1){
            cur = res+c+c+res+c+d+res+c+e+res+d;
            ask = press(cur);
            if (ask == n+2) res += c;
            else if (ask == n+1) res += d;
            else res += e;
            n++;
        }
        ask = press(res+c);
        if (ask == N)  res+=c;
        else{
            int ask2 = press(res+d);
            if (ask2 == N) res+=d;
            else res+=e;}
        
    }
    return res;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...