#include <bits/stdc++.h>
using namespace std;
#include "Joi.h"
namespace UF1 {
int tata[100010];
int g[100010];
int find(int x) {
if (tata[tata[x]] != tata[x])
tata[x] = find(tata[x]);
return tata[x];
}
bool unite(int a, int b) {
a = find(a);
b = find(b);
if (a == b)
return false;
if (g[a] > g[b])
g[a] += g[b], tata[b] = a;
else
g[b] += g[a], tata[a] = b;
return true;
}
void init() {
for (int i(0); i <= 100000; i++)
tata[i] = i, g[i] = 1;
}
}
static int col[100010], colact;
static vector <int> adia[100010];
static int poz_in_adia[100010];
static int fii[100010];
static int tata[100010];
static int nrcol = 60;
static int biti[64];
static int unknown;
static int viz[100010];
static void mk_cols(int nod)
{
if (tata[nod] != -1)
adia[nod].erase(find(adia[nod].begin(), adia[nod].end(), tata[nod]));
col[nod] = colact;
colact = (colact + 1) % nrcol;
MessageBoard(nod, biti[col[nod]]);
for (int i(0); i < adia[nod].size(); i++) {
tata[adia[nod][i]] = nod;
mk_cols(adia[nod][i]);
}
}
static void proc_input(int n, int m, int * a, int * b, long long x)
{
UF1::init();
for (int i(0); i < n; i++)
adia[i].clear();
for (int i(0); i < m; i++) {
if (UF1::unite(a[i], b[i])) {
adia[a[i]].push_back(b[i]);
adia[b[i]].push_back(a[i]);
}
}
for (int i(0); i < nrcol; i++) {
biti[i] = x & 1ll;
x >>= 1;
}
tata[0] = -1;
mk_cols(0);
}
void Joi(int N, int M, int A[], int B[], long long X, int T)
{
proc_input(N, M, A, B, X);
}
#include <bits/stdc++.h>
using namespace std;
#include "Ioi.h"
namespace UF {
int tata[100010];
int g[100010];
int find(int x) {
if (tata[tata[x]] != tata[x])
tata[x] = find(tata[x]);
return tata[x];
}
bool unite(int a, int b) {
a = find(a);
b = find(b);
if (a == b)
return false;
if (g[a] > g[b])
g[a] += g[b], tata[b] = a;
else
g[b] += g[a], tata[a] = b;
return true;
}
void init() {
for (int i(0); i <= 100000; i++)
tata[i] = i, g[i] = 1;
}
}
static int col[100010], colact;
static vector <int> adia[100010];
static int poz_in_adia[100010];
static int fii[100010];
static int tata[100010];
static int nrcol = 60;
static int biti[64];
static int unknown;
static int viz[100010];
static void mk_cols(int nod)
{
if (tata[nod] != -1)
adia[nod].erase(find(adia[nod].begin(), adia[nod].end(), tata[nod]));
col[nod] = colact;
colact = (colact + 1) % nrcol;
for (int i(0); i < adia[nod].size(); i++) {
poz_in_adia[adia[nod][i]] = i;
tata[adia[nod][i]] = nod;
mk_cols(adia[nod][i]);
}
}
static void proc_input(int n, int m, int * a, int * b)
{
UF::init();
for (int i(0); i < n; i++)
adia[i].clear();
for (int i(0); i < m; i++) {
if (UF::unite(a[i], b[i])) {
adia[a[i]].push_back(b[i]);
adia[b[i]].push_back(a[i]);
}
}
unknown = nrcol;
for (int i(0); i < nrcol; i++)
biti[i] = -1;
tata[0] = -1;
mk_cols(0);
}
static void add_bit(int col, int bit)
{
if (biti[col] == -1)
unknown--;
biti[col] = bit;
}
static void dfs(int nod, int i, int c)
{
add_bit(col[nod], c);
if (!unknown)
return;
viz[nod] = 1;
if (adia[nod].empty() || viz[adia[nod][i % adia[nod].size()]]) {
assert(tata[nod] != -1);
int x = Move(tata[nod]);
return dfs(tata[nod], poz_in_adia[nod] + 1, x);
}
else {
i %= adia[nod].size();
int x = Move(adia[nod][i]);
return dfs(adia[nod][i], 0, x);
}
}
long long Ioi(int N, int M, int A[], int B[], int P, int V, int T)
{
proc_input(N, M, A, B);
dfs(P, 0, V);
long long x(0);
for (int i(0); i < nrcol; i++)
x += biti[i] << i;
return x;
}
Compilation message
Joi.cpp: In function 'void mk_cols(int)':
Joi.cpp:51:22: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for (int i(0); i < adia[nod].size(); i++) {
~~^~~~~~~~~~~~~~~~~~
Joi.cpp: At global scope:
Joi.cpp:40:12: warning: 'viz' defined but not used [-Wunused-variable]
static int viz[100010];
^~~
Joi.cpp:39:12: warning: 'unknown' defined but not used [-Wunused-variable]
static int unknown;
^~~~~~~
Joi.cpp:35:12: warning: 'fii' defined but not used [-Wunused-variable]
static int fii[100010];
^~~
Joi.cpp:34:12: warning: 'poz_in_adia' defined but not used [-Wunused-variable]
static int poz_in_adia[100010];
^~~~~~~~~~~
Ioi.cpp: In function 'void mk_cols(int)':
Ioi.cpp:50:22: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for (int i(0); i < adia[nod].size(); i++) {
~~^~~~~~~~~~~~~~~~~~
Ioi.cpp: At global scope:
Ioi.cpp:35:12: warning: 'fii' defined but not used [-Wunused-variable]
static int fii[100010];
^~~
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Incorrect |
9 ms |
7020 KB |
Wrong Answer [7] |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Incorrect |
34 ms |
9724 KB |
Wrong Answer [7] |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Incorrect |
8 ms |
9872 KB |
Wrong Answer [7] |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Incorrect |
45 ms |
10200 KB |
Wrong Answer [7] |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Incorrect |
35 ms |
10708 KB |
Wrong Answer [7] |
2 |
Halted |
0 ms |
0 KB |
- |