# | TimeUTC-0 | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
1176482 | Zero_OP | Data Transfer (IOI19_transfer) | C++20 | 5 ms | 1728 KiB |
#include "transfer.h"
#include <bits/stdc++.h>
using namespace std;
std::vector<int> get_attachment(std::vector<int> source) {
int N = (int)source.size();
vector<int> send = source;
int b = 0;
while((1 << b) <= (N+1)) ++b;
vector<int> parity(b);
// cout << b << '\n';
for(int i = 0; i < N; ++i) if(source[i] == 0){
for(int j = 0; j < b; ++j) if((i+1) >> j & 1) parity[j] ^= 1;
}
// for(auto it : send) cout << it; cout << '\n';
return parity;
}
std::vector<int> retrieve(std::vector<int> data) {
int L = (int)data.size();
//L = N + 32 - __builtin_clz(N)
// for(auto it : data) cout << it; cout << '\n';
int N = -1, b = -1;
for(int i = 1; i < L; ++i){
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |