#include <bits/stdc++.h>
#include "Joi.h"
using namespace std;
typedef long long ll;
typedef long double ld;
typedef pair<int, int> pi;
typedef pair<ll, ll> pl;
typedef vector<int> vi;
typedef vector<ld> vd;
typedef vector<ll> vl;
#define pb push_back
#define f first
#define s second
namespace debug {
const int DEBUG = true;
template<class T1, class T2>
void pr(const pair<T1, T2> &x);
template<class T, size_t SZ>
void pr(const array<T, SZ> &x);
template<class T>
void pr(const vector<T> &x);
template<class T>
void pr(const set<T> &x);
template<class T1, class T2>
void pr(const map<T1, T2> &x);
template<class T>
void pr(const T &x) { if (DEBUG) cout << x; }
template<class T, class... Ts>
void pr(const T &first, const Ts &... rest) { pr(first), pr(rest...); }
template<class T1, class T2>
void pr(const pair<T1, T2> &x) { pr("{", x.f, ", ", x.s, "}"); }
template<class T>
void prIn(const T &x) {
pr("{");
bool fst = 1;
for (auto &a : x) {
pr(fst ? "" : ", ", a), fst = 0;
}
pr("}");
}
template<class T, size_t SZ>
void pr(const array<T, SZ> &x) { prIn(x); }
template<class T>
void pr(const vector<T> &x) { prIn(x); }
template<class T>
void pr(const set<T> &x) { prIn(x); }
template<class T1, class T2>
void pr(const map<T1, T2> &x) { prIn(x); }
void ps() { pr("\n"), cout << flush; }
template<class Arg, class... Args>
void ps(const Arg &first, const Args &... rest) {
pr(first, " ");
ps(rest...);
}
}
using namespace debug;
namespace shared {
const int MAXN = 1e4 + 10;
int N;
int M;
vi aL[MAXN];
vi tL[MAXN];
int par[MAXN];
bool vis[MAXN];
int maxH[MAXN];
int type[MAXN];
int mode = -1;
void dfs(int cV) {
vis[cV] = true;
for (int aV : aL[cV]) {
if (!vis[aV]) {
dfs(aV);
tL[cV].pb(aV);
par[aV] = cV;
}
}
}
void dfs2(int cV) {
for (int aV : tL[cV]) {
dfs2(aV);
maxH[cV] = max(maxH[cV], maxH[aV] + 1);
}
}
void dfs3(int cV, int cT) {
type[cV] = cT;
for (int aV : tL[cV]) {
dfs3(aV, (cT + 1) % 60);
}
}
vi assigned;
int nType = 0;
int dfs4(int cV, int bound, bool lastG) {
if (bound == 0) return 0;
type[cV] = nType++;
assigned.pb(cV);
bound--;
if (!lastG) { // if it isn't last, pick randomly
for (int aV : tL[cV]) {
bound = dfs4(aV, bound, false);
}
assigned.pb(-1);
return bound;
}
assert(lastG);
int bigC = -1;
for (int aV : tL[cV]) {
if (maxH[aV] == maxH[cV] - 1) {
bigC = aV;
break;
}
}
if (tL[cV].empty()) {
assert(bound == 0);
return 0;
}
assert(bigC != -1);
// we need to reserve at least maxH[bigC] for last
int avail = bound - maxH[bigC];
for (int aV : tL[cV]) {
if (aV != bigC) {
avail = dfs4(aV, avail, false);
}
}
int fBound = maxH[bigC] + avail; // in case we weren't able to fulfill needs earlier
int rem = dfs4(bigC, fBound, true);
assert(rem == 0);
return 0;
}
void prep(int iN, int iM, int A[], int B[]) {
N = iN, M = iM;
for (int i = 0; i < M; i++) {
aL[A[i]].pb(B[i]);
aL[B[i]].pb(A[i]);
}
fill(vis, vis + MAXN, false);
fill(par, par + MAXN, -1);
dfs(0);
fill(maxH, maxH + MAXN, 1);
dfs2(0);
fill(type, type + MAXN, -1);
if (maxH[0] >= 60) {
mode = 0;
dfs3(0, 0);
} else {
mode = 1;
dfs4(0, 60, true);
}
}
}
using namespace shared;
void Joi(int N, int M, int A[], int B[], ll X, int T) {
prep(N, M, A, B);
// ps(assigned);
int bits[60];
for (int i = 0; i < 60; i++) {
bits[i] = ((1ll << i) & X) != 0;
}
for (int i = 0; i < N; i++) {
if (type[i] != -1) {
MessageBoard(i, bits[type[i]]);
} else {
MessageBoard(i, 0); // default 0
}
}
}
#include <bits/stdc++.h>
#include "Ioi.h"
using namespace std;
typedef long long ll;
typedef long double ld;
typedef pair<int, int> pi;
typedef pair<ll, ll> pl;
typedef vector<int> vi;
typedef vector<ld> vd;
typedef vector<ll> vl;
#define pb push_back
#define f first
#define s second
namespace shared2 {
const int MAXN = 1e4 + 10;
int N;
int M;
vi aL[MAXN];
vi tL[MAXN];
int par[MAXN];
bool vis[MAXN];
int maxH[MAXN];
int type[MAXN];
int mode = -1;
void dfs(int cV) {
vis[cV] = true;
for (int aV : aL[cV]) {
if (!vis[aV]) {
dfs(aV);
tL[cV].pb(aV);
par[aV] = cV;
}
}
}
void dfs2(int cV) {
for (int aV : tL[cV]) {
dfs2(aV);
maxH[cV] = max(maxH[cV], maxH[aV] + 1);
}
}
void dfs3(int cV, int cT) {
type[cV] = cT;
for (int aV : tL[cV]) {
dfs3(aV, (cT + 1) % 60);
}
}
vi assigned;
int nType = 0;
int dfs4(int cV, int bound, bool lastG) {
if (bound == 0) return 0;
type[cV] = nType++;
assigned.pb(cV);
bound--;
if (!lastG) { // if it isn't last, pick randomly
for (int aV : tL[cV]) {
bound = dfs4(aV, bound, false);
}
assigned.pb(-1);
return bound;
}
assert(lastG);
int bigC = -1;
for (int aV : tL[cV]) {
if (maxH[aV] == maxH[cV] - 1) {
bigC = aV;
break;
}
}
if (tL[cV].empty()) {
assert(bound == 0);
return 0;
}
assert(bigC != -1);
// we need to reserve at least maxH[bigC] for last
int avail = bound - maxH[bigC];
for (int aV : tL[cV]) {
if (aV != bigC) {
avail = dfs4(aV, avail, false);
}
}
int fBound = maxH[bigC] + avail; // in case we weren't able to fulfill needs earlier
int rem = dfs4(bigC, fBound, true);
assert(rem == 0);
return 0;
}
void prep(int iN, int iM, int A[], int B[]) {
N = iN, M = iM;
for (int i = 0; i < M; i++) {
aL[A[i]].pb(B[i]);
aL[B[i]].pb(A[i]);
}
fill(vis, vis + MAXN, false);
fill(par, par + MAXN, -1);
dfs(0);
fill(maxH, maxH + MAXN, 1);
dfs2(0);
fill(type, type + MAXN, -1);
if (maxH[0] >= 60) {
mode = 0;
dfs3(0, 0);
} else {
mode = 1;
dfs4(0, 60, true);
}
}
}
using namespace shared2;
ll process0(int cV, ll cVal) {
while (type[cV] != 0) {
cV = par[cV];
cVal = Move(cV);
}
ll ans = 0;
ans |= cVal;
for (int i = 1; i < 60; i++) {
for (int aV : tL[cV]) {
if (maxH[aV] == maxH[cV] - 1) {
cV = aV;
cVal = Move(cV);
// cout << "cVal: " << cVal << endl;
// cout << "i: " << i << endl;
ans |= cVal << i;
// cout << "intAns: " << ans << endl;
break;
}
}
}
return ans;
}
ll process1(int cV, ll cVal) {
while (cV != 0) {
cV = par[cV];
cVal = Move(cV);
}
ll ans = 0;
assert(assigned[0] == 0);
ans |= cVal;
int i = 1;
for (int x : assigned) {
if (x == 0) continue;
if (x != -1) {
cV = x;
cVal = Move(cV);
ans |= cVal << i;
i++;
} else {
cV = par[cV];
cVal = Move(cV);
}
}
return ans;
}
ll Ioi(int N, int M, int A[], int B[], int initV, int firstVal, int T) {
prep(N, M, A, B);
ll ans;
if (mode == 0) {
ans = process0(initV, firstVal);
} else {
ans = process1(initV, firstVal);
}
// cout << "mode: " << mode << endl;
// cout << "think: " << ans << endl;
return ans;
}
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
10 ms |
1940 KB |
Output is correct |
2 |
Correct |
10 ms |
2056 KB |
Output is correct |
3 |
Correct |
11 ms |
2148 KB |
Output is correct |
4 |
Correct |
10 ms |
1936 KB |
Output is correct |
5 |
Correct |
10 ms |
1928 KB |
Output is correct |
6 |
Correct |
10 ms |
2040 KB |
Output is correct |
7 |
Correct |
10 ms |
2188 KB |
Output is correct |
8 |
Correct |
10 ms |
2296 KB |
Output is correct |
9 |
Correct |
10 ms |
2180 KB |
Output is correct |
10 |
Correct |
10 ms |
1940 KB |
Output is correct |
11 |
Incorrect |
14 ms |
2380 KB |
Wrong Answer [7] |
12 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
41 ms |
5508 KB |
Output is correct |
2 |
Incorrect |
40 ms |
5332 KB |
Wrong Answer [7] |
3 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
10 ms |
2036 KB |
Output is correct |
2 |
Correct |
10 ms |
2288 KB |
Output is correct |
3 |
Incorrect |
10 ms |
1908 KB |
Wrong Answer [7] |
4 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
40 ms |
5364 KB |
Output is correct |
2 |
Correct |
41 ms |
5332 KB |
Output is correct |
3 |
Correct |
40 ms |
5464 KB |
Output is correct |
4 |
Correct |
27 ms |
3828 KB |
Output is correct |
5 |
Incorrect |
27 ms |
5300 KB |
Wrong Answer [7] |
6 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
40 ms |
5372 KB |
Output is correct |
2 |
Correct |
41 ms |
5424 KB |
Output is correct |
3 |
Correct |
47 ms |
5360 KB |
Output is correct |
4 |
Correct |
27 ms |
3832 KB |
Output is correct |
5 |
Incorrect |
27 ms |
5348 KB |
Wrong Answer [7] |
6 |
Halted |
0 ms |
0 KB |
- |