Submission #139370

#TimeUsernameProblemLanguageResultExecution timeMemory
139370atoizCombo (IOI18_combo)C++14
100 / 100
57 ms2124 KiB
#include "combo.h" #include <vector> #include <algorithm> #include <cstdio> #include <iostream> using namespace std; vector<char> ch = {'A', 'B', 'X', 'Y'}; char firstChar() { int coins; coins = press(string(1, ch[0]) + string(1, ch[1])); if (coins == 2) return ch[0]; else if (coins == 1) { coins = press(string(1, ch[0])); if (coins == 1) return ch[0]; else { swap(ch[0], ch[1]); return ch[0]; } } else { coins = press(string(1, ch[2])); if (coins == 1) { swap(ch[0], ch[2]); return ch[0]; } else { swap(ch[0], ch[3]); return ch[0]; } } } char lastChar(string S) { int coins; coins = press(S + string(1, ch[0]) + S + string(1, ch[1])); if (coins == S.size() + 1) { coins = press(S + string(1, ch[0])); if (coins == S.size() + 1) return ch[0]; else return ch[1]; } else { coins = press(S + string(1, ch[2])); if (coins == S.size() + 1) return ch[2]; else return ch[3]; } } string guess_sequence(int N) { string S = string(1, firstChar()); if (N == 1) return S; int coins; vector<string> str(4); for (int i = 0; i < 4; ++i) str[i] = string(1, ch[i]); for (int i = 2; i < N; ++i) { // cerr << S << ": " << S + str[1] + str[1] + S + str[1] + str[2] + S + str[1] + str[3] + S + str[2]; coins = press(S + str[1] + str[1] + S + str[1] + str[2] + S + str[1] + str[3] + S + str[2]); // cerr << " " << coins << endl; if (coins == S.size() + 2) { S += str[1]; } else if (coins == S.size() + 1) { S += str[2]; } else { S += str[3]; } } S += string(1, lastChar(S)); return S; }

Compilation message (stderr)

combo.cpp: In function 'char lastChar(std::string)':
combo.cpp:41:15: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   41 |     if (coins == S.size() + 1) {
      |         ~~~~~~^~~~~~~~~~~~~~~
combo.cpp:43:19: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   43 |         if (coins == S.size() + 1) return ch[0];
      |             ~~~~~~^~~~~~~~~~~~~~~
combo.cpp:47:19: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   47 |         if (coins == S.size() + 1) return ch[2];
      |             ~~~~~~^~~~~~~~~~~~~~~
combo.cpp: In function 'std::string guess_sequence(int)':
combo.cpp:64:19: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   64 |         if (coins == S.size() + 2) {
      |             ~~~~~~^~~~~~~~~~~~~~~
combo.cpp:66:26: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   66 |         } else if (coins == S.size() + 1) {
      |                    ~~~~~~^~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...