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 <bits/stdc++.h>
using namespace std;
struct dsu {
vector<int> ds;
dsu() {}
dsu(int n) {
ds.assign(n, -1);
}
const int& operator[](int i) {
return ds[i];
}
int find(int i) {
return ds[i] < 0 ? i : ds[i] = find(ds[i]);
}
int size(int i) {
return -ds[find(i)];
}
bool same(int i, int j) {
return find(i) == find(j);
}
bool join(int i, int j) {
i = find(i), j = find(j);
if (i == j)
return false;
if (ds[i] > ds[j])
swap(i, j);
ds[i] += ds[j], ds[j] = i;
return true;
}
};
const int N = 20 * 2 + 1;
string process(vector<vector<string>> ss, int i, int j, int k, int n) {
static int on[N][N];
int n_ = (k + 1) * 2 + 1;
if (k == 0)
for (int x1 = 0; x1 < 3; x1++)
for (int y1 = 0; y1 < 3; y1++)
on[i + x1][j + y1] = ss[x1][y1][0] - '0';
if (k < n - 1)
return string(100, '0');
else {
dsu ds(n_ * n_);
int m;
for (int x = 0; x < n_; x++)
for (int y = 0; y < n_; y++)
if (on[x][y]) {
if (x > 0 && on[x - 1][y])
ds.join(x * n_ + y, (x - 1) * n_ + y);
if (y > 0 && on[x][y - 1])
ds.join(x * n_ + y, x * n_ + (y - 1));
}
m = 0;
for (int i = 0; i < n_ * n_; i++)
if (ds[i] < 0 && on[i / n_][i % n_])
m++;
string t(100, '0');
for (int b = 0; b < 10; b++)
t[b] = '0' + (m >> b & 1);
return t;
}
}
# | 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... |
# | 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... |