Java Program to Implement Disjoint Sets

This Java program is to Implement Disjoint Sets. A disjoint-set data structure is a data structure that keeps track of a set of elements partitioned into a number of disjoint (nonoverlapping) subsets. A union-find algorithm is an algorithm that performs two useful operations on such a data structure:
Find: Determine which subset a particular element is in.This can be used for determining if two elements are in the same subset.
Union: Join two subsets into a single subset.

Here is the source code of the Java program to implement Disjoint Sets. The Java program is successfully compiled and run on a Linux system. The program output is also shown below.

import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
 
public class DisjointSets
{
    private List<Map<Integer, Set<Integer>>> disjointSet;
 
    public DisjointSets()
    {
        disjointSet = new ArrayList<Map<Integer, Set<Integer>>>();
    }
 
    public void create_set(int element)
    {
        Map<Integer, Set<Integer>> map = new HashMap<Integer, Set<Integer>>();
        Set<Integer> set = new HashSet<Integer>();
        set.add(element);
        map.put(element, set);
        disjointSet.add(map);
    }
 
    public void union(int first, int second)
    {
        int first_rep = find_set(first);
        int second_rep = find_set(second);
 
        Set<Integer> first_set = null;
        Set<Integer> second_set = null;
        for (int index = 0; index < disjointSet.size(); index++)
        {
            Map<Integer, Set<Integer>> map = disjointSet.get(index);
            if (map.containsKey(first_rep))
            {
                first_set = map.get(first_rep);
            } else if (map.containsKey(second_rep))
            {
                second_set = map.get(second_rep);
            }
        }
        if (first_set != null && second_set != null)
            first_set.addAll(second_set);
        for (int index = 0; index < disjointSet.size(); index++)
        {
            Map<Integer, Set<Integer>> map = disjointSet.get(index);
            if (map.containsKey(first_rep))
            {
                map.put(first_rep, first_set);
            } else if (map.containsKey(second_rep))
            {
                map.remove(second_rep);
                disjointSet.remove(index);
            }
        }
        return;
    }
 
    public int find_set(int element)
    {
        for (int index = 0; index < disjointSet.size(); index++)
        {
            Map<Integer, Set<Integer>> map = disjointSet.get(index);
            Set<Integer> keySet = map.keySet();
            for (Integer key : keySet)
            {
                Set<Integer> set = map.get(key);
                if (set.contains(element))
                {
	            return key;
                }
            }
        }
        return -1;
    }
 
    public int getNumberofDisjointSets()
    {
        return disjointSet.size();
    }
 
    public static void main(String... arg)
    {
        DisjointSets disjointSet = new DisjointSets();
 
        for (int i = 1; i <= 5; i++)
        {
            disjointSet.create_set(i);
        }
        System.out.println("ELEMENT : REPRESENTATIVE KEY");
        for (int i = 1; i <= 5; i++)
        {
            System.out.println(i + "\t:\t" + disjointSet.find_set(i));
        }
        disjointSet.union(1, 5);
        disjointSet.union(5, 3);
 
        System.out.println("\nThe Representative keys after performing the union operation\n");
        System.out.println("Union of (1 and 5)  and (5 and 3) ");
        System.out.println("ELEMENT : REPRESENTATIVE KEY");
        for (int i = 1; i <= 5; i++)
        {
            System.out.println(i + "\t:\t" + disjointSet.find_set(i));
        }
        System.out.println("\nThe number of disjoint set : " + disjointSet.getNumberofDisjointSets());
    }
}
$javac DisjointSets.java
$java  DisjointSets
 
ELEMENT : REPRESENTATIVE KEY
1	:	1
2	:	2
3	:	3
4	:	4
5	:	5
 
The Representative keys after performing the union operation
Union of (1 and 5)  and (5 and 3)
 
ELEMENT : REPRESENTATIVE KEY
1	:	1
2	:	2
3	:	1
4	:	4
5	:	1
 
The number of disjoint set : 3

Related posts:

Validations for Enum Types
Spring MVC Async vs Spring WebFlux
The Spring @Controller and @RestController Annotations
Jackson – JsonMappingException (No serializer found for class)
Java Program to Implement Miller Rabin Primality Test Algorithm
Collection trong java
Java Program to Search Number Using Divide and Conquer with the Aid of Fibonacci Numbers
Integer Constant Pool trong Java
How to Get the Last Element of a Stream in Java?
ArrayList trong java
Hướng dẫn Java Design Pattern – State
Java 8 Streams peek() API
Inject Parameters into JUnit Jupiter Unit Tests
Using the Map.Entry Java Class
Java Program to Perform Addition Operation Using Bitwise Operators
Map Interface trong java
Java Program to Implement PrinterStateReasons API
Calling Stored Procedures from Spring Data JPA Repositories
Semaphore trong Java
Ways to Iterate Over a List in Java
Vòng lặp for, while, do-while trong Java
Java Program to Implement CopyOnWriteArraySet API
Java Program to Implement LinkedBlockingQueue API
Java Program to Solve any Linear Equation in One Variable
Performance Difference Between save() and saveAll() in Spring Data
Java Program to Apply DFS to Perform the Topological Sorting of a Directed Acyclic Graph
Implementing a Binary Tree in Java
Java Program to Check Whether a Given Point is in a Given Polygon
Spring RestTemplate Request/Response Logging
Java Program to Check if a Point d lies Inside or Outside a Circle Defined by Points a, b, c in a Pl...
Spring Web Annotations
Java – Get Random Item/Element From a List