이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "combo.h"
using namespace std;
const int NB_MAX_CARACTERES = 2000+1;
string res = "";
bool estPossible[NB_MAX_CARACTERES][3];
string guess_sequence (int nbElements)
{
fill(*estPossible, *estPossible+NB_MAX_CARACTERES*3, true);
if (press("AB") > 0) {
res += press("A") ? 'A' : 'B';
}
else {
res += press("X") ? 'X' : 'Y';
}
if (nbElements == 1) {
return res;
}
string caracteres;
for (char c : "ABXY") {
if (c != res[0]) {
caracteres.push_back(c);
}
}
while ((int)res.size() < nbElements) {
string requete = res;
while ((int)requete.size() < nbElements) {
for (int iCaractere=0; true; iCaractere++) {
if (estPossible[requete.size()][iCaractere]) {
requete += caracteres[iCaractere];
break;
}
}
}
const int reponse = press(requete);
while ((int)res.size() < reponse) {
res += requete[res.size()];
}
if ((int)res.size() < nbElements) {
const int iCaractere = distance(caracteres.begin(), find(caracteres.begin(), caracteres.end(), requete[res.size()]));
estPossible[res.size()][iCaractere] = false;
}
}
return res;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |