# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
76535 | darthsidious | Combo (IOI18_combo) | C++14 | 48 ms | 604 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <iostream>
#include <string>
//A B X Y
using namespace std;
int press(string p);
// {
// string secret = "ABXYXXYY";
// int ans = 0;
// for(int i=0;i<secret.size();i++) {
// if(secret[i] == p[i])
// ans++;
// else
// break;
// }
// return ans;
// }
string guess_sequence(int N) {
string chars = "ABXY";
string c[3];
int start_c = 3;
int x = press("AB");
// cout << "x = " << x << endl;
if(x >= 1) {
if(press("A") == 1)
start_c = 0;
else
start_c = 1;
}
else {
if(press("X") == 1)
start_c = 2;
}
// for(int i=0;i<3;i++) {
// string tmp(1, chars[i]);
// int r = press(tmp);
// if(r == 1) {
// start_c = i;
// break;
// }
// }
for(int i=0;i<3;i++) {
if(start_c <= i)
c[i] = string(1, chars[i+1]);
else
c[i] = string(1, chars[i]);
}
// cout << c[0] << c[1] << c[2] << endl;
string ans(1, chars[start_c]);
// cout << "Starting with " << ans << endl;
for(int i=0;i<7996;i++) {
int correct = ans.size();
if(correct == N)
break;
if(correct == N -1) {
int r = press(ans + c[0]);
if(r == N)
return ans + c[0];
r = press(ans + c[1]);
if(r == N)
return ans + c[1];
return ans + c[2];
// for(int k=0;k<3;k++) {
// r = press(ans + c[k]);
// if(r == N)
// return ans + c[k];
// }
// return ans;
}
string test = ans + c[0] + ans + c[1] + c[0] + ans + c[1] + c[1] + ans + c[1] + c[2];
if(test.size() > 4*N)
cout << "wtf";
int res = press(test);
// cout << "Result: " << res << " test: " << test << " correct: " << correct << endl;
if(res == correct)
ans += c[2];
else if(res == correct + 1)
ans += c[0];
else if(res == correct + 2)
ans += c[1];
// cout << "testing " << test << endl;
if((int)ans.size() == N)
break;
}
return ans;
}
// int main() {
// cout << guess_sequence(8) << endl;
// }
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |