1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
| class UnionFind { private final int[] fa; private final int[] size; public int cc;
UnionFind(int n) { fa = new int[n]; for (int i = 0; i < n; ++i) { fa[i] = i; } size = new int[n]; Arrays.fill(size, 1); cc = n; }
public int find(int x) { if (fa[x] != x) { fa[x] = find(fa[x]); } return fa[x]; }
public boolean isSame(int x, int y) { return find(x) == find(y); }
public boolean merge(int from, int to) { int x = find(from); int y = find(to); if (x == y) { return false; } fa[x] = y; size[y] += size[x]; cc--; return true; }
public int getSize(int x) { return size[find(x)]; } }
|