이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "encoder.h"
#include "encoderlib.h"
void encode(int N, int M[])
{
int i,j;
int ix = 0;
int cnt[256] = { 0 };
int bit8 = 1 << 7;
int bit;
int n = N < 32 ? N : 32;
for (i = 0; i < n; i++){
bit = bit8;
for (j = 0; j < 8; j++, bit >>= 1, ix++)
if (bit&M[i])
cnt[ix]++;
}
for (ix=0; i < N; i++){
bit = bit8;
for (j = 0; j < 8; j++, bit >>= 1, ix++)
if (bit&M[i])
cnt[ix] += 2;
}
for (i = 0; i < 256; i++)
while (cnt[i]--) send(i);
}
#include "decoder.h"
#include "decoderlib.h"
void decode(int N, int L, int X[])
{
int i,j;
int cnt[256] = { 0 };
int recover;
int n = N < 32 ? N : 32;
for (i = 0; i < L; i++)
cnt[X[i]]++;
for (i = 0,n*=8; i < n;){
recover = 0;
for (j = 0; j < 8; j++, i++){
recover <<= 1;
if (cnt[i]&1)
recover += 1;
}
output(recover);
}
for (N *= 8; i < N;){
recover = 0;
for (j = 0; j < 8; j++, i++){
recover <<= 1;
if (cnt[i] & 2)
recover += 1;
}
output(recover);
}
}
# | 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... |