이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "combo.h"
#include <bits/stdc++.h>
using namespace std;
std::string guess_sequence(int N) {
string s;
string ans;
auto third_subtask = [&](int n){
string cur = "ABXY";
string s;
string ans;
ans+=cur[0];
ans+=cur[1];
if (press(ans) > 0){
ans.pop_back();
if (press(ans) == 1){
for (int j = 0;j<4;++j){
if (j != 0){
s+=cur[j];
}
}
}
else{
ans.pop_back();
ans+=cur[1];
for (int j = 0;j<4;++j){
if (j != 1){
s+=cur[j];
}
}
}
}
else{
ans.pop_back();
ans.pop_back();
ans+=cur[2];
if (press(ans) == 1){
for (int j = 0;j<4;++j){
if (j != 2){
s+=cur[j];
}
}
}
else{
ans.pop_back();
ans+=cur[3];
for (int j = 0;j<4;++j){
if (j != 3){
s+=cur[j];
}
}
}
}
if (n == 1)return ans;
//n + 1 + n + 2
for (int i = 0;i<n - 2;++i){
string p = ans;
p+=s[0];
for (int j = 0;j<3;++j){
string t = ans;
t+=s[1];
t+=s[j];
p+=t;
}
if (press(p) == i + 2){
ans+=s[0];
}
else if (press(p) == i + 1){
ans+=s[2];
}
else{
ans+=s[1];
}
}
for (int i = 0;i<2;++i){
ans+=s[i];
if (press(ans) == n){
return ans;
}
ans.pop_back();
}
ans+=s[2];
return ans;
};
string v = third_subtask(N);
cout<<v<<'\n';
return v;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |