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 "prison.h"
#include <bits/stdc++.h>
using namespace std;
vector<vector<int>> devise_strategy(int N) {
vector<vector<int>> v(23, vector<int>(N + 1, 0));
int i = 0, j = 1728, zz = 1, jj;
v[i][0] = 0;
for (int k = 1; k <= N; k++) {
v[i][k] = 1 + ((k / j) % 3);
}
for (i = 1; i < 10; i += 3) {
jj = j / 3;
for (int k = 0; k < 3; k++) v[i + k][0] = zz;
for (int k = 1; k <= N; k++) {
int z = (k / j) % 3;
for (int y1 = 0; y1 < 3; y1++) {
if (y1 < z) v[i + y1][k] = -2+zz;
else if (y1 > z) v[i + y1][k] = -1-zz;
else v[i + y1][k] = i + 3 + ((k / jj) % 3);
}
}
zz = 1 - zz;
j = jj;
}
jj = j / 2;
for (int k = 0; k < 3; k++) v[i + k][0] = zz;
for (int k = 1; k <= N; k++) {
int z = (k / j) % 3;
for (int y1 = 0; y1 < 3; y1++) {
if (y1 < z) v[i + y1][k] = -2+zz;
else if (y1 > z) v[i + y1][k] = -1-zz;
else v[i + y1][k] = i + 3 + ((k / jj) % 2);
}
}
zz = 1 - zz;
j = jj;
for (i = 13; i < 21; i += 2) {
jj = j / 2;
for (int k = 0; k < 2; k++) v[i + k][0] = zz;
for (int k = 1; k <= N; k++) {
int z = (k / j) % 2;
for (int y1 = 0; y1 < 2; y1++) {
if (y1 < z) v[i + y1][k] = -2+zz;
else if (y1 > z) v[i + y1][k] = -1-zz;
else v[i + y1][k] = i + 2 + ((k / jj) % 2);
}
}
zz = 1 - zz;
j = jj;
}
jj = j / 2;
for (int k = 0; k < 2; k++) v[i + k][0] = zz;
for (int k = 1; k <= N; k++) {
int z = (k / j) % 2;
for (int y1 = 0; y1 < 2; y1++) {
if (y1 < z) v[i + y1][k] = -2+zz;
else if (y1 > z) v[i + y1][k] = -1-zz;
else if (k / jj % 2 == 1) v[i + y1][k] = -2+zz;
else v[i + y1][k] = -1-zz;
}
}
return v;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |