This is a Java Program to Implement Warshall Transitive closure Algorithm. Warshall’s Transitive closure algorithm is used to determine if a path exists from vertex a to vertex b for all vertex pairs (a, b) in a graph.
Here is the source code of the Java Program to Implement Warshall Algorithm. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
/**
** Java Program to Implement Warshall Algorithm
**/
import java.util.Scanner;
/** Class Warshall **/
public class Warshall
{
private int V;
private boolean[][] tc;
/** Function to make the transitive closure **/
public void getTC(int[][] graph)
{
this.V = graph.length;
tc = new boolean[V][V];
for (int i = 0; i < V; i++)
{
for (int j = 0; j < V; j++)
if (graph[i][j] != 0)
tc[i][j] = true;
tc[i][i] = true;
}
for (int i = 0; i < V; i++)
{
for (int j = 0; j < V; j++)
{
if (tc[j][i])
for (int k = 0; k < V; k++)
if (tc[j][i] && tc[i][k])
tc[j][k] = true;
}
}
}
/** Funtion to display the trasitive closure **/
public void displayTC()
{
System.out.println("\nTransitive closure :\n");
System.out.print(" ");
for (int v = 0; v < V; v++)
System.out.print(" " + v );
System.out.println();
for (int v = 0; v < V; v++)
{
System.out.print(v +" ");
for (int w = 0; w < V; w++)
{
if (tc[v][w])
System.out.print(" * ");
else
System.out.print(" ");
}
System.out.println();
}
}
/** Main function **/
public static void main (String[] args)
{
Scanner scan = new Scanner(System.in);
System.out.println("Warshall Algorithm Test\n");
/** Make an object of Warshall class **/
Warshall w = new Warshall();
/** Accept number of vertices **/
System.out.println("Enter number of vertices\n");
int V = scan.nextInt();
/** get graph **/
System.out.println("\nEnter matrix\n");
int[][] graph = new int[V][V];
for (int i = 0; i < V; i++)
for (int j = 0; j < V; j++)
graph[i][j] = scan.nextInt();
w.getTC(graph);
w.displayTC();
}
}
Warshall Algorithm Test
Enter number of vertices
6
Enter matrix
0 1 0 0 0 1
0 0 0 0 0 0
1 0 0 1 0 0
0 0 0 0 0 0
0 0 0 1 0 0
0 0 0 0 1 0
Transitive closure :
0 1 2 3 4 5
0 * * * * *
1 *
2 * * * * * *
3 *
4 * *
5 * * *
Related posts:
Prevent Cross-Site Scripting (XSS) in a Spring Application
Apache Commons Collections MapUtils
Java Program to Implement Stack using Two Queues
Java Program to Generate Random Numbers Using Middle Square Method
Java Program to Represent Graph Using 2D Arrays
Hướng dẫn Java Design Pattern – Dependency Injection
Using a List of Values in a JdbcTemplate IN Clause
Spring Boot - Enabling Swagger2
Hướng dẫn Java Design Pattern – Bridge
Java – Create a File
Hướng dẫn Java Design Pattern – Observer
A Custom Data Binder in Spring MVC
Deque và ArrayDeque trong Java
Examine the internal DNS cache
Giới thiệu Google Guice – Binding
Java Program to Implement SynchronosQueue API
Java Program to Decode a Message Encoded Using Playfair Cipher
Spring Cloud AWS – S3
Java Program to Implement ScapeGoat Tree
Jackson – JsonMappingException (No serializer found for class)
Java Program to Perform the Unique Factorization of a Given Number
Spring Boot Actuator
Logging a Reactive Sequence
How to Remove the Last Character of a String?
Java Program to Implement Sieve Of Atkin
Marker Interface trong Java
Hướng dẫn Java Design Pattern – DAO
Java 8 Streams peek() API
Java – Write an InputStream to a File
Java Program to Implement Hash Tables with Linear Probing
Spring Boot - Service Components
Compact Strings in Java 9