| # | Time | Username | Problem | Language | Result | Execution time | Memory |
|---|---|---|---|---|---|---|---|
| 1310757 | lizi14 | Data Transfer (IOI19_transfer) | C++20 | 7 ms | 3252 KiB |
#include "transfer.h"
#include <bits/stdc++.h>
using namespace std;
int N;
vector<int> get_attachment(vector<int>source){
N=source.size();
vector<int>k={0,0,0,0,0,0,0,0};
int bati=0;
for(int i=1; i<=N; i++){
if(source[i-1]==1){
bati^=i;
}
}
vector<int>h;
for(int i=0; i<=log2(bati); i++){
if(bati&(1<<i))h.push_back(1);
else h.push_back(0);
}
int ixvi=0;
for(int i=0; i<h.size(); i++){
k[i]=h[i];
if(h[i]==1)ixvi++;
}
vector<int>data;
data=source;
for(int i=0; i<k.size(); i++){
data.push_back(k[i]);
}
//data=data+(k.begin(), k.end());
if(ixvi%2==0)data.push_back(0);
else data.push_back(1);
return data;
//return { 0, 1, 0 };
}
vector<int>retrieve(vector<int>data){
int bati=0;
for(int i=1; i<=N; i++){
if(data[i-1]==1){
bati^=i;
}
}
int ixvi=0;
int drnachvi=0;
for(int i=N; i<N+8; i++){
if(data[i]==1){
drnachvi++;
ixvi+=(1<<(i-N));
}
}
if(ixvi==bati){
vector<int>v;
for(int i=0; i<N; i++){
v.push_back(data[i]);
}
return v;
}
int m=data.size();
if(drnachvi%2==data[m-1]){
int idex=ixvi^bati;
vector<int>v;
for(int i=0; i<N; i++){
if(i==idex-1){
v.push_back(1-data[i]);
continue;
}
else{
v.push_back(data[i]);
}
}
return v;
}
else{
vector<int>v;
for(int i=0; i<N; i++){
v.push_back(data[i]);
}
return v;
}
//return vector<int>(data.begin(), data.end()-3);
}
Compilation message (stderr)
| # | Verdict | Execution time | Memory | Grader output |
|---|---|---|---|---|
| Fetching results... | ||||
| # | Verdict | Execution time | Memory | Grader output |
|---|---|---|---|---|
| Fetching results... | ||||
