Submission #1285891

#TimeUsernameProblemLanguageResultExecution timeMemory
1285891minhnguyent546Data Transfer (IOI19_transfer)C++20
0 / 100
4 ms1720 KiB
/**            
 * author      minhnguyent546
 * created_at  Fri, 2025-10-31 21:24:00
 **/           
#include <vector>
#include <cassert>
#include "transfer.h"


std::vector<int> get_attachment(std::vector<int> source) {
    int n = (int) source.size();
    assert (n == 63 || n == 255);
    int x = 0;
    for (int i = 0; i < n; ++i) {
        if (source[i] == 1) x ^= i;
    }
    // cerr << "x = " << x << '\n';
    int sz;
    if (n == 63) {
        sz = 6;
    } else {
        sz = 8;
    }
    std::vector<int> b(sz + 1);
    int cur = x;
    int one = 0;
    for (int i = 0; i < sz; ++i) {
        if ((cur >> i) & 1) {
            ++one;
            b[i] = 1;
        }
    }
    b[sz] = (one & 1 ? 1 : 0);
    return b;
}

std::vector<int> retrieve(std::vector<int> data) {
    int sz = (int) data.size();
    int k, n;
    assert(sz == 70 || sz == 264);
    if (sz == 70) {
        n = 63;
        k = 6;
    } else {
        n = 255;
        k = 8;
    }
    int one = 0;
    for (int i = n; i < sz; ++i) {
        one += data[i];
    }
    if (one % 2 == 0) {
        // corrupted in N bits
        int x = 0;
        for (int i = 0; i < k; ++i) {
            if (data[i + n] == 1) {
                x += (1 << i);
            }
        }
        for (int i = 0; i < n; ++i) {
            if (data[i] == 1) x ^= i;
        }
        // corrupted position is x;
        // cerr << "x = " << x << '\n';
        assert (x >= 0 && x < n);
        data[x] ^= 1;
    } else {
        // corrupted in K bits;
    }
    return std::vector<int>(data.begin(), data.begin() + n);
}

Compilation message (stderr)

grader.cpp: In instantiation of 'void shuffle(std::vector<T>&) [with T = Scenario]':
grader.cpp:200:10:   required from here
grader.cpp:28:23: warning: 'void std::random_shuffle(_RAIter, _RAIter) [with _RAIter = __gnu_cxx::__normal_iterator<Scenario*, vector<Scenario> >]' is deprecated: use 'std::shuffle' instead [-Wdeprecated-declarations]
   28 |         random_shuffle(v.begin(), v.end());
      |         ~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~
In file included from /usr/include/c++/13/algorithm:61,
                 from grader.cpp:8:
/usr/include/c++/13/bits/stl_algo.h:4581:5: note: declared here
 4581 |     random_shuffle(_RandomAccessIterator __first, _RandomAccessIterator __last)
      |     ^~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...