# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
573452 | Deepesson | 앵무새 (IOI11_parrots) | C++17 | 6 ms | 1348 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
/**Encoder**/
#include <bits/stdc++.h>
#include "encoder.h"
#include "encoderlib.h"
void send(int a);
std::string enviar;
int qtdzeros,qtduns;
void inserezero(void){
if(!qtdzeros)assert(0);
--qtdzeros;
enviar+="0";
}
void insereum(void){
if(!qtduns)assert(0);
--qtduns;
enviar+="1";
}
std::string plano;
void codificar_e_enviar(){
//std::cout<<enviar<<" envia\n";
int cur=0;
int count=0;
for(auto&x:enviar){
if(x=='1'){
++cur;
}else {send(cur);++count;}
}
}
void encode(int N, int M[])
{
qtduns=256;
qtdzeros=N*5;
enviar="";
plano="";
int count = 0;
for(int i=0;i!=N;++i){
for(int j=0;j!=8;++j){
bool valor = (bool)(M[i]&(1<<j));
count+=valor;
plano.push_back(valor+48);
}
}
if(count>256){
enviar+="1";
}else enviar+="0";
for(int i=0;i!=plano.size();++i){
bool valor = plano[i]-48;
if(count>256){
valor=!valor;
}
enviar+=valor+48;
}
codificar_e_enviar();
}
/**Decoder**/
#include <bits/stdc++.h>
#include "decoder.h"
#include "decoderlib.h"
void output(int b);
void decode(int N, int L, int X[])
{
int count[256]={};
for(int i=0; i<L; i++) {
count[X[i]]++;
}
std::string trueseq;
int cur=0;
while(cur!=256){
if(count[cur]){
--count[cur];
trueseq.push_back('0');
}else {
++cur;
trueseq.push_back('1');
}
}
// std::cout<<"Recebe "<<trueseq<<"\n";
cur=1;
bool inverte = trueseq[0]-48;
for(int i=0;i!=N;++i){
int ans=0;
for(int j=0;j!=8;++j){
int p = (1<<j);
bool k = trueseq[cur]-48;
if(inverte)k=!k;
if(k)ans+=p;
++cur;
}
output(ans);
}
}
컴파일 시 표준 에러 (stderr) 메시지
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |