# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
211571 | Harry464 | Combo (IOI18_combo) | C++14 | 40 ms | 652 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>
#include <cmath>
#include "combo.h"
using namespace std;
string guess_sequence(int N) {
char slovo[4]={'A','B','X','Y'};
int prvoSlovo, odgovor;
string s;
if(press("AB"))
{
if(press("A")) prvoSlovo=0;
else prvoSlovo=1;
}
else
{
if(press("X")) prvoSlovo=2;
else prvoSlovo=3;
}
s+=slovo[prvoSlovo];
if (s.size() == N)
return s;
for(int i=2;i<N;i++)
{
string t = s + slovo[(prvoSlovo+1)%4] + slovo[(prvoSlovo+1)%4] + s + slovo[(prvoSlovo+1)%4] + slovo[(prvoSlovo+2)%4] + s + slovo[(prvoSlovo+1)%4] + slovo[(prvoSlovo+3)%4] + s + slovo[(prvoSlovo+2)%4];
odgovor = press(t);
int l = s.size();
if(odgovor == l+2) s += slovo[(prvoSlovo+1)%4];
else if(odgovor == l+1) s+=slovo[(prvoSlovo+2)%4];
else s+=slovo[(prvoSlovo+3)%4];
}
int l = s.size();
if(press(s + slovo[(prvoSlovo+1)%4] + s + slovo[(prvoSlovo+2)%4])>l)
{
if(press(s+slovo[(prvoSlovo+1)%4])>l) s+=slovo[(prvoSlovo+1)%4];
else s+=slovo[(prvoSlovo+2)%4];
}
else
{
s+=slovo[(prvoSlovo+3)%4];
}
return s;
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |