Submission #605449

#TimeUsernameProblemLanguageResultExecution timeMemory
605449AmirElarbiCombo (IOI18_combo)C++14
94 / 100
32 ms564 KiB
#include <bits/stdc++.h> #define vi vector<int> #define gi greater<int> #define gr greater #define ve vector #define ll long long #define vf vector<float> #define vll vector<pair<ll,ll>> #define ii pair<int,int> #define pll pair<ll,ll> #define vvi vector<vi> #define vii vector<ii> #define gii greater<ii> #define pb push_back #define mp make_pair #define fi first #define se second #define INF 1e9 #define eps 1e-7 #define eps1 1e-2 #define optimise ios_base::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL); #define MAX_A 2e5+5 using namespace std; const int MOD = 1e9+7; const int nax = 1e6+5; typedef complex<int> Point; #define X real() #define Y imag() #include "combo.h" string guess_sequence(int n) { string s = ""; int beg = 0; if(press("A")) beg = 0,s = "A"; else if(press("B")) beg = 1,s= "B"; else if(press("X")) beg = 2,s = "X"; else beg = 3,s = "Y"; for (int i = 2; i < n; ++i) { if(beg == 0){ string cur = s+"X"+s+"YX"+s+"YY"+s+"YB"; int a = press(cur); if(a == i-1) s+="B"; else if(a == i) s+="X"; else s += "Y"; } else if(beg == 1){ string cur = s+"X"+s+"YX"+s+"YY"+s+"YA"; int a = press(cur); if(a == i-1) s+="A"; else if(a == i) s+="X"; else s += "Y"; } else if(beg == 2){ string cur = s+"A"+s+"YA"+s+"YY"+s+"YB"; int a = press(cur); if(a == i-1) s+="B"; else if(a == i) s+="A"; else s += "Y"; } else { string cur = s+"A"+s+"BA"+s+"BX"+s+"BB"; int a = press(cur); if(a == i-1) s+="X"; else if(a == i) s+="A"; else s += "B"; } } if(n!=1){ if(press(s+"A") == n) s += "A"; else if(press(s+"B") == n) s += "B"; else if(press(s+"X") == n) s += "X"; else s += "Y"; } return s; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...