[Union Find]Graph Connect Tree
Last updated
Last updated
public class Solution {
/**
* @param n: An integer
* @param edges: a list of undirected edges
* @return: true if it's a valid tree, or false
*/
private static class UnionFind {
int[] father;
int count;
public UnionFind(int n) {
father = new int[n];
count = n;
for (int i = 0; i < n; i++) {
father[i] = i;
}
}
private int find(int x) {
if (father[x] == x) {
return father[x];
}
return father[x] = find(father[x]);
}
private void union(int a, int b) {
int root_a = find(a);
int root_b = find(b);
if (root_a != root_b) {
father[root_a] = root_b;
count--;
}
}
private boolean query(int a, int b) {
return find(a) == find(b);
}
}
public boolean validTree(int n, int[][] edges) {
// write your code here
if (n == 0) {
return false;
}
if (edges.length != n - 1) {
return false;
}
UnionFind uf = new UnionFind(n);
for (int[] edge : edges) {
//
// if (uf.query(edge[0], edge[1])) {
// return false;
// }
uf.union(edge[0], edge[1]);
}
return uf.count == 1;
}
}