siteName > > searches.UnionFind
Threads
java ( 1827371 ) - java ( 1827386 ) stack: com.thealgorithms.searches.UnionFind.main(UnionFind.java:67)
package com.thealgorithms.searches;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

public class UnionFind {

    private final int[] p;
    private final int[] r;

    public UnionFind(int n) {
        p = new int[n];
        r = new int[n];

        for (int i = 0; i < n; i++) {
            p[i] = i;
        }
    }

    public int find(int i) {
        int parent = p[i];

        if (i == parent) {
            return i;
        }

        final int result = find(parent);
        p[i] = result;

        return result;
    }

    public void union(int x, int y) {
        int r0 = find(x);
        int r1 = find(y);

        if (r1 == r0) {
            return;
        }

        if (r[r0] > r[r1]) {
            p[r1] = r0;
        } else if (r[r1] > r[r0]) {
            p[r0] = r1;
        } else {
            p[r1] = r0;
            r[r0]++;
        }
    }

    public int count() {
        List<Integer> parents = new ArrayList<>();
        for (int i = 0; i < p.length; i++) {
            if (!parents.contains(find(i))) {
                parents.add(find(i));
            }
        }
        return parents.size();
    }

    public String toString() {
        return "p " + Arrays.toString(p) + " r " + Arrays.toString(r) + "\n";
    }

    // Tests
    public static void main(String[] args) {
        UnionFind uf = new UnionFind(5);
        System.out.println("init /w 5 (should print 'p [0, 1, 2, 3, 4] r [0, 0, 0, 0, 0]'):");
        System.out.println(uf);

        uf.union(1, 2);
        System.out.println("union 1 2 (should print 'p [0, 1, 1, 3, 4] r [0, 1, 0, 0, 0]'):");
        System.out.println(uf);

        uf.union(3, 4);
        System.out.println("union 3 4 (should print 'p [0, 1, 1, 3, 3] r [0, 1, 0, 1, 0]'):");
        System.out.println(uf);

        uf.find(4);
        System.out.println("find 4 (should print 'p [0, 1, 1, 3, 3] r [0, 1, 0, 1, 0]'):");
        System.out.println(uf);

        System.out.println("count (should print '3'):");
        System.out.println(uf.count());
    }
}
Variables All
No.FromNameValue
167args[Ljava.lang.String;@7852e922
END 0 00
Output All Filter Merge
Process FilterThread Filter
1827371 java 1827386 java
No.PNPIDTIDTNMessage
1java18273711827386javainit /w 5 (should print 'p [0, 1, 2, 3, 4] r [0, 0, 0, 0, 0]'):
2java18273711827386javap [0, 1, 2, 3, 4] r [0, 0, 0, 0, 0]
3java18273711827386javaunion 1 2 (should print 'p [0, 1, 1, 3, 4] r [0, 1, 0, 0, 0]'):
4java18273711827386javap [0, 1, 1, 3, 4] r [0, 1, 0, 0, 0]
5java18273711827386javaunion 3 4 (should print 'p [0, 1, 1, 3, 3] r [0, 1, 0, 1, 0]'):
6java18273711827386javap [0, 1, 1, 3, 3] r [0, 1, 0, 1, 0]
7java18273711827386javafind 4 (should print 'p [0, 1, 1, 3, 3] r [0, 1, 0, 1, 0]'):
8java18273711827386javap [0, 1, 1, 3, 3] r [0, 1, 0, 1, 0]
9java18273711827386javacount (should print '3'):
END 0 0 0 00
Project:Alg-Java
Update:20240824
Commit:a7cd97d7
Source Code:searches.UnionFind
BuildTool:Java17
Compiler:Java17
Runtime:Openjdk17
System:MySystemD
Kernel:Linux5.10.211
Cpu:Intel:Corei7-7700K
Machine:AwesomeMachine