This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "encoder.h"
#include "encoderlib.h"
#include <bits/stdc++.h>
using namespace std;
#define int long long
#define all(x) x.begin(), x.end()
int nxt() {
int t;
cin >> t;
return t;
}
int dp[17][20];
vector<int> encode(int x) {
vector<int> res(20);
for (int j = 19; j >= 0; --j) {
for (int i = 0; i < 17; ++i) {
if (x - dp[i][j] < 0) {
res[j] = i;
break;
}
x -= dp[i][j];
}
}
while (res.back() == 16) res.pop_back();
return res;
}
void encode(int32_t n, int32_t vc[]) {memset(dp,0,sizeof dp);
for (int i = 0; i < 17; ++i) dp[i][0] = 1;
for (int j = 1; j < 20; ++j) {
for (int i = 0; i < 17; ++i) {
for (int k = 0; k <= i; ++k) {
dp[i][j] += dp[k][j - 1];
}
}
}
vector<int> v(vc, vc+n);
while (n % 4) {
v.push_back(0);
++n;
}
vector<int> ans;
for (int i = 0; i < n; i += 4) {
auto x = encode((v[i] << 24) + (v[i + 1] << 16) + (v[i + 2] << 8) + v[i + 3]);
for (int j : x) ans.push_back(((i / 4) << 4) + j);
}
for (int i : ans) send(i);
}
#include "decoder.h"
#include "decoderlib.h"
#include <bits/stdc++.h>
using namespace std;
#define int long long
#define all(x) x.begin(), x.end()
int nxt() {
int t;
cin >> t;
return t;
}
int dp[17][20];
int decode(vector<int> x) {
sort(all(x));
while (x.size() < 20) x.push_back(16);
int res = 0;
for (int j = 0; j < 20; ++j) {
for (int i = 1; i < 17; ++i) {
if (x[j] >= i) res += dp[i - 1][j];
}
}
return res;
}
void decode(int32_t n, int32_t m, int32_t vc[]) {memset(dp, 0,sizeof dp);
for (int i = 0; i < 17; ++i) dp[i][0] = 1;
for (int j = 1; j < 20; ++j) {
for (int i = 0; i < 17; ++i) {
for (int k = 0; k <= i; ++k) {
dp[i][j] += dp[k][j - 1];
}
}
}
vector<int> u[16];
for (int j = 0; j < m; ++j) {
int i = vc[j];
int idx = i >> 4;
u[idx].push_back(i & 15);
}
vector<int> ans;
for (auto x : u) { // n!
if (x.empty()) continue;
int y = decode(x);
ans.push_back(y >> 24);
ans.push_back(y >> 16 & 255);
ans.push_back(y >> 8 & 255);
ans.push_back(y & 255);
}
for (int i = 0; i < n; ++i) output(ans[i]);
}
# | 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... |