Submission #1039076

#TimeUsernameProblemLanguageResultExecution timeMemory
1039076VMaksimoski008콤보 (IOI18_combo)C++17
30 / 100
32 ms1900 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) {
            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:24:43: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   24 |             if(press(S + vec[0] + vec[1]) == S.size() + 2) {
      |                ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:27:50: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   27 |             } else if(press(S + vec[1] + vec[2]) == S.size() + 2) {
      |                       ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:34:90: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   34 |         } else if(press(S + vec[1] + vec[0] + S + vec[2] + vec[1] + S + vec[2] + vec[0]) == S.size() + 2) {
      |                   ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:35:43: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   35 |             if(press(S + vec[1] + vec[0]) == S.size() + 2) {
      |                ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:38:50: 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(press(S + vec[2] + vec[1]) == S.size() + 2) {
      |                       ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:46:43: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   46 |             if(press(S + vec[0] + vec[0]) == S.size() + 2) {
      |                ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:49:50: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   49 |             } else if(press(S + vec[1] + vec[1]) == S.size() + 2) {
      |                       ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:59:17: warning: comparison of integer expressions of different signedness: 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   59 |     if(S.size() < N) {
      |        ~~~~~~~~~^~~
combo.cpp:60:30: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   60 |         if(press(S + vec[0]) == S.size() + 1) S += vec[0];
      |            ~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
combo.cpp:61:35: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   61 |         else if(press(S + vec[1]) == S.size() + 1) S += vec[1];
      |                 ~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...