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>
#ifdef local
#define debug(args...) qqbx(#args, args)
template <typename ...T> void qqbx(const char *s, T ...args) {
int f = 0;
((std::cerr << "(" << s << ") = (") , ... , (std::cerr << (f++ ? ", " : "") << args)), std::cerr << ")\n";
}
#else
#define debug(...) ((void)0)
#endif // local
using namespace std;
const int maxn = 100025, mod = 1e9;
namespace dsu {
int pa[maxn], sz[maxn];
void init(int N) {
for (int i = 0; i < N; i++) pa[i] = i, sz[i] = 1;
}
int anc(int x) {
return x==pa[x] ? x : pa[x] = anc(pa[x]);
}
bool join(int x, int y) {
if ((x=anc(x)) == (y=anc(y))) return false;
if (sz[x] < sz[y]) swap(x, y);
return pa[y] = x, sz[x] += sz[y], true;
}
}
struct Point {
int x, y, id;
} pts[maxn];
vector<int> tr[maxn];
bool vis[maxn];
int dep[maxn];
void dfs(int i) {
vis[i] = true;
for (int j: tr[i]) {
if (vis[j]) continue;
dep[j] = dep[i] + 1;
dfs(j);
}
}
int ans;
void solve(int N) {
for (int i = 0; i < N; i++) tr[i].clear(), vis[i] = false;
sort(pts, pts + N, [](Point a, Point b) { return a.x != b.x ? a.x < b.x : a.y < b.y; });
dsu::init(N);
for (int i = 1; i < N; i++) {
if (pts[i].x == pts[i-1].x && pts[i].y == pts[i-1].y + 1)
dsu::join(pts[i].id, pts[i-1].id);
}
for (int i = 0; i < N; i++) if(i == dsu::anc(i)) {
int x;
for (int j = 0; j < N; j++) if (pts[j].id == i) x = pts[j].x;
debug(i, dsu::sz[i], x);
}
sort(pts, pts + N, [](Point a, Point b) { return a.y != b.y ? a.y < b.y : a.x < b.x; });
for (int i = 1; i < N; i++) {
if (pts[i].y == pts[i-1].y && pts[i].x == pts[i-1].x + 1) {
int a = dsu::anc(pts[i].id);
int b = dsu::anc(pts[i-1].id);
tr[a].push_back(b);
tr[b].push_back(a);
}
}
#define sort_uni(v) sort(v.begin(),v.end()),v.erase(unique(v.begin(), v.end()), v.end())
for (int i = 0; i < N; i++)
sort_uni(tr[i]);
// for (int i = 0; i < N; i++) if(tr[i].size()) {
// cerr << i << " -> ";
// for (int j: tr[i]) cerr << j << ' ';
// cerr << '\n';
// }
for (int s = 0; s < N; s++) {
for (int j = 0; j < N; j++) vis[j] = false;
dep[s] = 0;
dfs(s);
for (int j = 0; j < s; j++) if(vis[j]) ans += dsu::sz[s] * dsu::sz[j] * dep[j];
}
// dfs(0);
debug("HERE");
}
int DistanceSum(int N, int *X, int *Y) {
ans = 0;
for (int i = 0; i < N; i++)
pts[i] = { X[i], Y[i], i };
solve(N);
for (int i = 0; i < N; i++)
pts[i] = { Y[i], X[i], i };
solve(N);
return ans % mod;
}
Compilation message (stderr)
city.cpp: In function 'void solve(int)':
city.cpp:54:13: warning: variable 'x' set but not used [-Wunused-but-set-variable]
54 | int x;
| ^
# | 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... |