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