Submission #1039073

#TimeUsernameProblemLanguageResultExecution timeMemory
1039073VMaksimoski008콤보 (IOI18_combo)C++17
0 / 100
0 ms596 KiB
#include "combo.h"
#include <bits/stdc++.h>
using namespace std;


string guess_sequence(int N) {
    string S = "";

    if(press("XY")) {
        if(press("X")) S += 'X';
        else S += 'Y';
    } else if(press("A")) {
        S += 'A';
    } else {
        S += 'B';
    }

    vector<char> vec;
    for(auto &ch : {'A', 'B', 'X', 'Y'}) if(ch != S[0]) vec.push_back(ch);

    //press(p) dava dolzina na najdolg prefix na S sto e substring na p
    while(S.size() + 1 < N) {
        if(press(S + vec[0] + vec[1] + S + vec[1] + vec[2] + S + vec[0] + vec[2]) == S.size() + 2) {
            cout << 1 << '\n';
            if(press(S + vec[0] + vec[1]) == S.size() + 2) {
                S += vec[0];
                S += vec[1];
            } else if(press(S + vec[1] + vec[2]) == S.size() + 2) {
                S += vec[1];
                S += vec[2];
            } else {
                S += vec[0];
                S += vec[2];
            }
        } else if(press(S + vec[1] + vec[0] + S + vec[2] + vec[1] + S + vec[2] + vec[0]) == S.size() + 2) {
            if(press(S + vec[1] + vec[0]) == S.size() + 2) {
                S += vec[1];
                S += vec[0];
            } else if(press(S + vec[2] + vec[1]) == S.size() + 2) {
                S += vec[2];
                S += vec[1];
            } else {
                S += vec[2];
                S += vec[0];
            }
        } else {
            if(press(S + vec[0] + vec[0]) == S.size() + 2) {
                S += vec[0];
                S += vec[0];
            } else if(press(S + vec[1] + vec[1]) == S.size() + 2) {
                S += vec[1];
                S += vec[1];
            } else {
                S += vec[2];
                S += vec[2];
            }
        }
    }

    if(S.size() < N) {
        if(press(S + vec[0]) == S.size() + 1) S += vec[0];
        else if(press(S + vec[1]) == S.size() + 1) S += vec[1];
        else S += vec[2];
    }

    return S;
}

Compilation message (stderr)

combo.cpp: In function 'std::string guess_sequence(int)':
combo.cpp:22:24: warning: comparison of integer expressions of different signedness: 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   22 |     while(S.size() + 1 < N) {
      |           ~~~~~~~~~~~~~^~~
combo.cpp:23:83: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   23 |         if(press(S + vec[0] + vec[1] + S + vec[1] + vec[2] + S + vec[0] + vec[2]) == S.size() + 2) {
      |            ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:25:43: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   25 |             if(press(S + vec[0] + vec[1]) == S.size() + 2) {
      |                ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:28:50: 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(press(S + vec[1] + vec[2]) == S.size() + 2) {
      |                       ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:35:90: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   35 |         } else if(press(S + vec[1] + vec[0] + S + vec[2] + vec[1] + S + vec[2] + vec[0]) == S.size() + 2) {
      |                   ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:36:43: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   36 |             if(press(S + vec[1] + vec[0]) == S.size() + 2) {
      |                ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:39:50: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   39 |             } else if(press(S + vec[2] + vec[1]) == S.size() + 2) {
      |                       ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:47:43: 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(press(S + vec[0] + vec[0]) == S.size() + 2) {
      |                ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:50:50: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   50 |             } else if(press(S + vec[1] + vec[1]) == S.size() + 2) {
      |                       ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:60:17: warning: comparison of integer expressions of different signedness: 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   60 |     if(S.size() < N) {
      |        ~~~~~~~~~^~~
combo.cpp:61:30: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   61 |         if(press(S + vec[0]) == S.size() + 1) S += vec[0];
      |            ~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:62:35: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   62 |         else if(press(S + vec[1]) == S.size() + 1) S += vec[1];
      |                 ~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...