# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
357882 | 2021-01-24T21:36:33 Z | Ahmad_Hasan | Data Transfer (IOI19_transfer) | C++17 | 10 ms | 3168 KB |
#include <bits/stdc++.h> #include "transfer.h" using namespace std; vector<int> get_attachment(vector<int>src){ if(1) return src; long long p=31; long long mod=1e9+7; long long ppow=1ll; long long hsh=0ll; int n=src.size(); for(int i=0;i<n;i++){ hsh+=src[i]*ppow; hsh%=mod; ppow*=p; ppow%=mod; } vector<int>ret(30); for(int i=0;i<30;i++)ret[i]=!!(hsh&(1<<i)); return ret; } vector<int> retrieve(vector<int>data){ vector<int>ret; if(1){ int n=data.size(); for(int i=n/2;i<n;i++) ret.push_back(data[i]); }else{ long long p=31; long long mod=1e9+7; long long ppow=1ll; long long hsh=0ll; int n=data.size()-30; vector<int>ret; for(int i=0;i<n;i++){ hsh+=data[i]*ppow; hsh%=mod; ppow*=p; ppow%=mod; } int f=0; for(int i=n;i<data.size();i++){ if(data[i]!=!!(hsh&(1<<(i-n)))) f=1; } if(!f){ for(int i=0;i<n;i++){ ret.push_back(data[i]); } return ret; } for(int i=0;i<n;i++){ data[i]=!data[i]; p=31; mod=1e9+7; ppow=1ll; hsh=0ll; for(int i=0;i<n;i++){ hsh+=data[i]*ppow; hsh%=mod; ppow*=p; ppow%=mod; } int f=0; for(int i=n;i<data.size();i++){ if(data[i]!=!!(hsh&(1<<(i-n)))) f=1; } if(!f){ for(int i=0;i<n;i++){ ret.push_back(data[i]); } return ret; } data[i]=!data[i]; } } return ret; }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Incorrect | 4 ms | 1076 KB | WA in grader: wrong source retrieval |
2 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Incorrect | 10 ms | 3168 KB | WA in grader: wrong source retrieval |
2 | Halted | 0 ms | 0 KB | - |