| # | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
|---|---|---|---|---|---|---|---|
| 1310827 | lizi14 | Data Transfer (IOI19_transfer) | C++20 | 58 ms | 1728 KiB |
#include "transfer.h"
#include <bits/stdc++.h>
using namespace std;
vector<int>get_attachment(vector<int>source){
int N=source.size();
vector<int>k;
for(int i=0; i<=log2(N); i++){
k.push_back(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>dataa;
//dataa=source;
//cout<<bati<<endl;
for(int i=0; i<k.size(); i++){
dataa.push_back(k[i]);
//cout<<k[i]<<" ";
}
//cout<<endl;
//data=data+(k.begin(), k.end());
if(ixvi%2==0)dataa.push_back(0);
else dataa.push_back(1);
// for(auto a:dataa){
// cout<<a<<" ";
// }
// cout<<endl;
return dataa;
//return { 0, 1, 0 };
}
vector<int>retrieve(vector<int>data){
// for(auto a:data){
// cout<<a<<" ";
// }
//cout<<endl;
int bati=0;
int ka;
//cout<<data.size()<<endl;
if(data.size()>=100)ka=9;
else ka=7;
int N=data.size()-ka;
//cout<<N<<endl;
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+ka-1; i++){
if(data[i]==1){
drnachvi++;
ixvi+=(1<<(i-N));
}
}
//cout<<ixvi<<endl;
//cout<<bati<<endl;
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);
}
컴파일 시 표준 에러 (stderr) 메시지
| # | Verdict | Execution time | Memory | Grader output |
|---|---|---|---|---|
| Fetching results... | ||||
| # | Verdict | Execution time | Memory | Grader output |
|---|---|---|---|---|
| Fetching results... | ||||
