This Java program is to find the transitive closure of a graph.Given a directed graph, find out if a vertex j is reachable from another vertex i for all vertex pairs (i, j) in the given graph. Here reachable mean that there is a path from vertex i to j. The reach-ability matrix is called transitive closure of a graph.
Here is the source code of the Java program to find the transitive closure of graph. The Java program is successfully compiled and run on a Linux system. The program output is also shown below.
import java.util.Scanner;
public class TransitiveClosure
{
private int transitiveMatrix[][];
private int numberofvertices;
public static final int INFINITY = 999;
public TransitiveClosure(int numberofvertices)
{
transitiveMatrix= new int[numberofvertices + 1][numberofvertices + 1];
this.numberofvertices = numberofvertices;
}
public void transitiveClosure(int adjacencymatrix[][])
{
for (int source = 1; source <= numberofvertices; source++)
{
for (int destination = 1; destination <= numberofvertices; destination++)
{
transitiveMatrix[destination] = adjacencymatrix[destination];
}
}
for (int intermediate = 1; intermediate <= numberofvertices; intermediate++)
{
for (int source = 1; source <= numberofvertices; source++)
{
for (int destination = 1; destination <= numberofvertices; destination++)
{
if (transitiveMatrix[intermediate] + transitiveMatrix[intermediate][destination]
< transitiveMatrix[destination])
transitiveMatrix[destination] = transitiveMatrix[intermediate]
+ transitiveMatrix[intermediate][destination];
}
}
}
for (int source = 1; source <= numberofvertices; source++)
System.out.print("\t" + source);
System.out.println();
for (int source = 1; source <= numberofvertices; source++)
{
System.out.print(source + "\t");
for (int destination = 1; destination <= numberofvertices; destination++)
{
System.out.print(transitiveMatrix[destination] + "\t");
}
System.out.println();
}
}
public static void main(String... arg)
{
int adjacency_matrix[][];
int numberofvertices;
Scanner scan = new Scanner(System.in);
System.out.println("Enter the number of vertices");
numberofvertices = scan.nextInt();
adjacency_matrix = new int[numberofvertices + 1][numberofvertices + 1];
System.out.println("Enter the Weighted Matrix for the graph");
for (int source = 1; source <= numberofvertices; source++)
{
for (int destination = 1; destination <= numberofvertices; destination++)
{
adjacency_matrix[destination] = scan.nextInt();
if (source == destination)
{
adjacency_matrix[destination] = 0;
continue;
}
if (adjacency_matrix[destination] == 0)
{
adjacency_matrix[destination] = INFINITY;
}
}
}
System.out.println("The Transitive Closure of the Graph");
TransitiveClosure transitiveClosure = new TransitiveClosure(numberofvertices);
transitiveClosure.transitiveClosure(adjacency_matrix);
scan.close();
}
}
$javac TransitiveClosure.java $java TransitiveClosure Enter the number of vertices 4 Enter the Weighted Matrix for the graph 0 0 3 0 2 0 0 0 0 7 0 1 6 0 0 0 The Transitive Closure of the Graph 1 2 3 4 1 0 10 3 4 2 2 0 5 6 3 7 7 0 1 4 6 16 9 0
Related posts:
Java Program to Create a Random Linear Extension for a DAG
Function trong Java 8
Spring Boot - Application Properties
Java Program to implement Dynamic Array
JPA/Hibernate Persistence Context
Java Program to Check whether Directed Graph is Connected using BFS
How to Use if/else Logic in Java 8 Streams
Java Program to Construct an Expression Tree for an Prefix Expression
Java Program to Check Whether Graph is DAG
Getting Started with GraphQL and Spring Boot
Chuyển đổi Array sang ArrayList và ngược lại
Guide to the Synchronized Keyword in Java
Java Program to Represent Graph Using Adjacency Matrix
Retrieve User Information in Spring Security
Hướng dẫn Java Design Pattern – Bridge
Java Map With Case-Insensitive Keys
Java Program to Perform Arithmetic Operations on Numbers of Size
Java Program to Implement Interpolation Search Algorithm
Java Program to Implement Queue
Hướng dẫn Java Design Pattern – MVC
@Before vs @BeforeClass vs @BeforeEach vs @BeforeAll
Implementing a Runnable vs Extending a Thread
Configuring a DataSource Programmatically in Spring Boot
Spring MVC + Thymeleaf 3.0: New Features
Introduction to Spring Data REST
HashMap trong Java hoạt động như thế nào?
Java – File to Reader
Tiêu chuẩn coding trong Java (Coding Standards)
Cơ chế Upcasting và Downcasting trong java
Java Program to Check the Connectivity of Graph Using BFS
Câu lệnh điều khiển vòng lặp trong Java (break, continue)
Giới thiệu Google Guice – Injection, Scope