답안 #518730

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
518730 2022-01-24T13:50:42 Z LucaIlie Hidden Sequence (info1cup18_hidden) C++17
59 / 100
87 ms 296 KB
#include <iostream>
#include <vector>
#include "grader.h"
 
using namespace std;
 
vector <int> vans;
vector <int> seq;
 
bool ask( int nr0, int nr1, int s ) {
    int i;
 
    seq.clear();
 
    if ( nr0 + nr1 == 0 )
        return 1;
 
    for ( i = 0; i < nr1; i++ )
        seq.push_back( 1^s );
    for ( i = 0; i < nr0; i++ )
        seq.push_back( 0^s );
 
    return isSubsequence( seq );
}
 
void add( int b, int x ) {
    int i;
 
    for ( i = 0; i < x; i++ )
        vans.push_back( b );
}
 
vector <int> findSequence( int n ) {
    int nr0, nr1, s, zero, ram0, i;
 
    nr0 = 0;
    while ( nr0 <= n / 2 + 1 && ask( nr0, 0, 0 ) )
        nr0++;
    nr0--;
    if ( nr0 == n / 2 + 1 ) {
        while ( !ask( 0, n - nr0, 0 ) )
            nr0++;
        nr1 = nr0;
        nr0 = n - nr0;
        s = 1;
    } else {
        nr1 = n - nr0;
        s = 0;
    }
 
    ram0 = nr0;
    for ( i = 1; i <= nr1; i++ ) {
        zero = 0;
        while ( zero <= ram0 && ask( zero, i, s ) )
            zero++;
        zero--;
 
        add( s, ram0 - zero );
        ram0 = zero;
        add( !s, 1 );
    }
    add( s, ram0 );
 
    return vans;
}

Compilation message

grader.cpp: In function 'int main()':
grader.cpp:28:26: warning: format '%d' expects argument of type 'int', but argument 3 has type 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wformat=]
   28 |     fprintf (fifo_out, "%d\n", ans.size ());
      |                         ~^     ~~~~~~~~~~~
      |                          |              |
      |                          int            std::vector<int>::size_type {aka long unsigned int}
      |                         %ld
grader.cpp:29:20: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   29 |     for (int i=0; i<ans.size () && i < N; i++)
      |                   ~^~~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Partially correct 1 ms 200 KB Output is partially correct: Maximum length of a query = 6
2 Partially correct 1 ms 200 KB Output is partially correct: Maximum length of a query = 7
3 Correct 1 ms 200 KB Output is correct: Maximum length of a query = 5
4 Correct 0 ms 200 KB Output is correct: Maximum length of a query = 5
5 Partially correct 1 ms 200 KB Output is partially correct: Maximum length of a query = 5
# 결과 실행 시간 메모리 Grader output
1 Partially correct 46 ms 200 KB Output is partially correct: Maximum length of a query = 93
2 Partially correct 58 ms 200 KB Output is partially correct: Maximum length of a query = 103
3 Partially correct 65 ms 200 KB Output is partially correct: Maximum length of a query = 99
4 Partially correct 49 ms 280 KB Output is partially correct: Maximum length of a query = 90
5 Partially correct 62 ms 288 KB Output is partially correct: Maximum length of a query = 101
6 Partially correct 25 ms 200 KB Output is partially correct: Maximum length of a query = 99
7 Partially correct 59 ms 276 KB Output is partially correct: Maximum length of a query = 127
8 Partially correct 66 ms 276 KB Output is partially correct: Maximum length of a query = 110
9 Partially correct 67 ms 296 KB Output is partially correct: Maximum length of a query = 127
10 Partially correct 87 ms 292 KB Output is partially correct: Maximum length of a query = 123
11 Correct 64 ms 200 KB Output is correct: Maximum length of a query = 96
12 Partially correct 85 ms 288 KB Output is partially correct: Maximum length of a query = 149
13 Partially correct 74 ms 296 KB Output is partially correct: Maximum length of a query = 105