Submission #113496

#TimeUsernameProblemLanguageResultExecution timeMemory
113496Mamnoon_SiamCombo (IOI18_combo)C++17
100 / 100
55 ms548 KiB
#include "combo.h" #include <bits/stdc++.h> using namespace std; string guess_sequence(int N) { string ret; set<char> r; r.insert('A'); r.insert('B'); r.insert('X'); r.insert('Y'); if(press("AB")) { if(press("A")) { ret += "A", r.erase('A'); } else { ret += "B", r.erase('B'); } } else { if(press("X")) { ret += "X", r.erase('X'); } else { ret += "Y", r.erase('Y'); } } if(N == 1) return ret; vector<int> R(r.begin(), r.end()); for(int i = 2; i < N; i++) { string tmp; tmp += ret; tmp += R[0]; for(char ch : R) { tmp += ret; tmp += R[1]; tmp += ch; } int rep = press(tmp); if(rep == ret.size()) ret += R[2]; else if(rep == ret.size() + 1) ret += R[0]; else ret += R[1]; } for(int k = 0; k < 2; k++) { char ch = R[k]; string tmp = ret; tmp += ch; if(press(tmp) == N) { ret += ch; break; } } if(ret.size() != N) { ret += R[2]; } return ret; }

Compilation message (stderr)

combo.cpp: In function 'std::string guess_sequence(int)':
combo.cpp:37:16: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   37 |         if(rep == ret.size()) ret += R[2];
      |            ~~~~^~~~~~~~~~~~~
combo.cpp:38:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   38 |         else if(rep == ret.size() + 1) ret += R[0];
      |                 ~~~~^~~~~~~~~~~~~~~~~
combo.cpp:50:19: warning: comparison of integer expressions of different signedness: 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   50 |     if(ret.size() != N) {
      |        ~~~~~~~~~~~^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...