이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "encoder.h"
#include "encoderlib.h"
#include <bitset>
#include <cassert>
#include <iostream>
#include <array>
using namespace std;
const int LEN = 514, LIM = 517;
static bitset<LEN> operator+ (const bitset<LEN> &lhs, const bitset<LEN> &rhs) {
bitset<LEN> res;
res.reset();
bool carry = 0;
for (int i = 0; i < LEN; i++) {
res[i] = carry ^ lhs[i] ^ rhs[i];
if ((carry && lhs[i]) || (carry && rhs[i]) || (lhs[i] && rhs[i])) {
carry = 1;
} else {
carry = 0;
}
}
assert(carry == 0);
return res;
}
static bool fullSubtractor(bool b1, bool b2, bool& borrow) {
bool diff;
if (borrow) {
diff = !(b1 ^ b2);
borrow = !b1 || (b1 && b2);
}
else {
diff = b1 ^ b2;
borrow = !b1 && b2;
}
return diff;
}
static bitset<LEN> operator- (const bitset<LEN> &lhs, const bitset<LEN> &rhs) {
bool borrow = 0;
bitset<LEN> ans;
ans.reset();
for (int i = 0; i < LEN; i++) {
ans[i] = fullSubtractor(lhs[i], rhs[i], borrow);
}
return ans;
}
bool lessThanOrEqualTo(const bitset<LEN> &lhs, const bitset<LEN> &rhs) {
auto tmp = lhs ^ rhs;
int pos = -1;
for (int i = LEN - 1; i >= 0; i--) {
if (tmp[i]) {
pos = i;
break;
}
}
if (pos == -1 || rhs[pos]) return 1;
else return 0;
}
static bitset<LEN> nck[LIM][LIM];
static void precompute_binomials() {
for (int i = 0; i < LIM; i++) {
for (int j = 0; j <= i; j++) {
if (i == 0 || j == 0) {
nck[i][j] = j == 0;
} else {
nck[i][j] = nck[i - 1][j] + nck[i - 1][j - 1];
}
}
}
}
static bool init;
void encode(int N, int M[]) {
int K = min(262, N * 5);
if (!init) {
precompute_binomials();
init = 1;
}
bitset<LEN> cur;
cur.reset();
for (int i = 0; i < N; i++) {
for (int j = 0; j < 8; j++) {
cur[i * 8 + j] = !!(M[i] & (1 << j));
}
}
cur = cur + 1;
for (int i = 0, val = 0; i < K; i++) {
int len_left = K - 1 - i;
while (1) {
int vals_left = 255 - val;
if (lessThanOrEqualTo(nck[len_left + vals_left][vals_left], cur)) {
cur = cur - nck[len_left + vals_left][vals_left];
val++;
} else {
break;
}
}
send(val);
}
}
#include "decoder.h"
#include "decoderlib.h"
#include <bitset>
#include <cassert>
#include <iostream>
#include <algorithm>
#include <array>
using namespace std;
const int LEN = 514, LIM = 517;
static bitset<LEN> operator+ (const bitset<LEN> &lhs, const bitset<LEN> &rhs) {
bitset<LEN> res;
res.reset();
bool carry = 0;
for (int i = 0; i < LEN; i++) {
res[i] = carry ^ lhs[i] ^ rhs[i];
if ((carry && lhs[i]) || (carry && rhs[i]) || (lhs[i] && rhs[i])) {
carry = 1;
} else {
carry = 0;
}
}
assert(carry == 0);
return res;
}
static bool fullSubtractor(bool b1, bool b2, bool &borrow) {
bool diff = 0;
if (borrow) {
diff = !(b1 ^ b2);
borrow = !b1 || (b1 && b2);
} else {
diff = b1 ^ b2;
borrow = !b1 && b2;
}
return diff;
}
static bitset<LEN> operator- (const bitset<LEN> &lhs, const bitset<LEN> &rhs) {
bool borrow = 0;
bitset<LEN> ans;
ans.reset();
for (int i = 0; i < LEN; i++) {
ans[i] = fullSubtractor(lhs[i], rhs[i], borrow);
}
return ans;
}
static bitset<LEN> nck[LIM][LIM];
static void precompute_binomials() {
for (int i = 0; i < LIM; i++) {
for (int j = 0; j <= i; j++) {
if (i == 0 || j == 0) {
nck[i][j] = j == 0;
} else {
nck[i][j] = nck[i - 1][j] + nck[i - 1][j - 1];
}
}
}
}
static bool init;
void decode(int N, int L, int X[]) {
if (!init) {
precompute_binomials();
init = 1;
}
sort(X, X + L);
bitset<LEN> num(0);
for (int i = 0; i < L; i++) {
int len_left = L - i - 1;
for (int val = i ? X[i - 1] : 0; val < X[i]; val++) {
int val_left = 255 - val;
num = num + nck[len_left + val_left][val_left];
}
}
num = num - 1;
for (int i = 0; i < N; i++) {
int A = 0;
for (int j = 0; j < 8; j++) {
if (num[i * 8 + j]) {
A |= (1 << j);
}
}
output(A);
}
}
# | 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... |