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 <iostream>
#include <set>
#include <vector>
using i64 = int64_t;
struct UnionFind {
std::vector<i64> parent;
explicit UnionFind(size_t sz) : parent(sz, -1) {}
i64 find(i64 u) {
if (parent[u] < 0)
return u;
else
return parent[u] = find(parent[u]);
}
bool unite(i64 u, i64 v) {
u = find(u);
v = find(v);
if (u == v) {
return false;
} else {
if (-parent[u] < -parent[v])
std::swap(u, v);
parent[u] += parent[v];
parent[v] = u;
return false;
}
}
};
int main() {
std::cin.tie(nullptr)->sync_with_stdio(false);
i64 h, w;
std::cin >> h >> w;
std::vector<std::string> grid(h);
for (i64 i = 0; i < h; i++)
std::cin >> grid[i];
UnionFind dsu(h * w);
i64 idx = 0;
for (i64 r = 0; r < h; r++) {
const auto &row = grid[r];
for (i64 c = 0; c < w; c++, idx++) {
if (c + 1 < w && grid[r][c] == grid[r][c + 1]) {
dsu.unite(idx, idx + 1);
}
if (r + 1 < h && grid[r][c] == grid[r + 1][c]) {
dsu.unite(idx, idx + w);
}
}
}
std::vector<std::set<i64>> adj(h * w);
auto adge = [&](i64 u, i64 v) {
adj[dsu.find(u)].insert(dsu.find(v));
adj[dsu.find(v)].insert(dsu.find(u));
};
idx = 0;
for (i64 r = 0; r < h; r++) {
const auto &row = grid[r];
for (i64 c = 0; c < w; c++, idx++) {
if (row[c] == '.') continue;
char op = row[c] == 'F' ? 'R' : 'F';
if (c + 1 < w && grid[r][c + 1] == op) {
adge(idx, idx + 1);
}
if (r + 1 < h && grid[r + 1][c] == op) {
adge(idx, idx + w);
}
}
}
std::vector<i64> next;
std::vector<i64> front { dsu.find(0) };
std::vector<bool> visited(h * w, false);
visited[0] = true;
int t;
for (t = 0; !front.empty(); t++) {
for (int x : front) {
for (int neighbour : adj[x]) {
if (!visited[neighbour]) {
visited[neighbour] = true;
next.push_back(neighbour);
}
}
}
std::swap(next, front);
next.clear();
}
std::cout << t;
}
Compilation message (stderr)
tracks.cpp: In function 'int main()':
tracks.cpp:51:17: warning: unused variable 'row' [-Wunused-variable]
51 | const auto &row = grid[r];
| ^~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |