| # | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
|---|---|---|---|---|---|---|---|
| 1363852 | feyza | Data Transfer (IOI19_transfer) | C++20 | 5 ms | 3256 KiB |
#include <bits/stdc++.h>
#include "transfer.h"
using namespace std;
std::vector<int> get_attachment(std::vector<int> source)
{
int n=source.size();
int lgn;
vector<int>ans;
if(n==63)
{
ans.resize(70,0);
lgn=6;
}
else
{
ans.resize(264,0);
lgn=8;
}
for(int i=0;i<n;i++)
{
ans[i]=source[i];
ans[n]=(ans[n]^source[i]);
for(int j=0;j<lgn;j++)
{
if(i & (1<<j))
{
ans[n+1+j]^=ans[i];
}
}
}
return ans;
}
std::vector<int> retrieve(std::vector<int> data)
{
int n,lgn;
if(data.size()>=255)
{
n=255;
lgn=8;
}
else
{
n=63;
lgn=6;
}
vector<int>ans(n,0);
int check=0;
for(int i=0;i<n;i++)
{
ans[i]=data[i];
check^=ans[i];
}
if(data[n]==check)
return ans;
vector<int>v(lgn);
for(int i=0;i<n;i++)
{
for(int j=0;j<lgn;j++)
{
if(i & (1<<j))
{
v[j]^=data[i];
}
}
}
int pos=0;
for(int j=0;j<lgn;j++)
{
if(v[j]!=data[n+1+j])
pos+=(1<<j);
}
ans[pos]=1-ans[pos];
return ans;
}
컴파일 시 표준 에러 (stderr) 메시지
| # | 결과 | 실행 시간 | 메모리 | 채점기 출력 |
|---|---|---|---|---|
| 결과를 불러오는 중입니다… | ||||
| # | 결과 | 실행 시간 | 메모리 | 채점기 출력 |
|---|---|---|---|---|
| 결과를 불러오는 중입니다… | ||||
