Submission #741183

#TimeUsernameProblemLanguageResultExecution timeMemory
741183Charizard2021Combo (IOI18_combo)C++17
100 / 100
30 ms576 KiB
#include "combo.h" #include <bits/stdc++.h> using namespace std; string guess_sequence(int N) { string cur = ""; if(press("AB") >= 1){ cur = press("A") ? "A" : "B"; } else{ cur = press("X") ? "X" : "Y"; } vector<char> characters = {'A', 'B', 'X', 'Y'}; characters.erase(find(characters.begin(), characters.end(), cur[0])); while((int)cur.size() <= N - 2){ int query = press(cur + characters[0] + characters[0] + cur + characters[0] + characters[1] + cur + characters[1] + characters[0]); if(query == cur.size()){ cur.push_back(characters[2]); } else if(query == cur.size() + 1){ query = press(cur + characters[1] + characters[2]); if(query == cur.size()) cur = cur + characters[0] + characters[2]; else if(query == cur.size() + 1) cur = cur + characters[1] + characters[1]; else cur = cur + characters[1] + characters[2]; } else{ query = press(cur + characters[0] + characters[1]); if(query == cur.size()) cur = cur + characters[1] + characters[0]; else if(query == cur.size() + 1) cur = cur + characters[0] + characters[0]; else cur = cur + characters[0] + characters[1]; } } while(cur.size() != N){ if(press(cur + characters[0]) == cur.size() + 1){ cur.push_back(characters[0]); } else if(press(cur + characters[1]) == cur.size() + 1){ cur.push_back(characters[1]); } else cur.push_back(characters[2]); } return cur; }

Compilation message (stderr)

combo.cpp: In function 'std::string guess_sequence(int)':
combo.cpp:16:12: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   16 |   if(query == cur.size()){
      |      ~~~~~~^~~~~~~~~~~~~
combo.cpp:19:17: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   19 |   else if(query == cur.size() + 1){
      |           ~~~~~~^~~~~~~~~~~~~~~~~
combo.cpp:21:13: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   21 |    if(query == cur.size()) cur = cur + characters[0] + characters[2];
      |       ~~~~~~^~~~~~~~~~~~~
combo.cpp:22:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   22 |    else if(query == cur.size() + 1) cur = cur + characters[1] + characters[1];
      |            ~~~~~~^~~~~~~~~~~~~~~~~
combo.cpp:27:13: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   27 |    if(query == cur.size()) cur = cur + characters[1] + characters[0];
      |       ~~~~~~^~~~~~~~~~~~~
combo.cpp:28:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   28 |    else if(query == cur.size() + 1) cur = cur + characters[0] + characters[0];
      |            ~~~~~~^~~~~~~~~~~~~~~~~
combo.cpp:32:19: warning: comparison of integer expressions of different signedness: 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   32 |  while(cur.size() != N){
      |        ~~~~~~~~~~~^~~~
combo.cpp:33:33: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   33 |   if(press(cur + characters[0]) == cur.size() + 1){
      |      ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~
combo.cpp:36:38: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   36 |   else if(press(cur + characters[1]) == cur.size() + 1){
      |           ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...