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:
Java Program to Repeatedly Search the Same Text (such as Bible by building a Data Structure)
Spring Boot - Cloud Configuration Server
Java Program to Search for an Element in a Binary Search Tree
Spring REST API + OAuth2 + Angular
Guide to Character Encoding
A Quick Guide to Spring MVC Matrix Variables
Merging Streams in Java
Java Program to Check whether Undirected Graph is Connected using BFS
REST Web service: Basic Authentication trong Jersey 2.x
Guide to java.util.concurrent.Locks
Netflix Archaius with Various Database Configurations
Introduction to the Java NIO2 File API
Java Program to Implement Fisher-Yates Algorithm for Array Shuffling
Java Program to Implement Sorted Circular Doubly Linked List
Java – Reader to InputStream
Java Program to Perform Encoding of a Message Using Matrix Multiplication
Integer Constant Pool trong Java
Query Entities by Dates and Times with Spring Data JPA
How to Iterate Over a Stream With Indices
Java Program to Implement Find all Forward Edges in a Graph
Converting String to Stream of chars
Removing Elements from Java Collections
Java Program to Implement Min Hash
Intersection of Two Lists in Java
Java CyclicBarrier vs CountDownLatch
DynamoDB in a Spring Boot Application Using Spring Data
The Thread.join() Method in Java
Java Program to Use Above Below Primitive to Test Whether Two Lines Intersect
Chuyển đổi từ HashMap sang ArrayList
Immutable ArrayList in Java
Java Program to Implement Pollard Rho Algorithm
Java Program to Implement Knapsack Algorithm