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:
Spring Boot - Service Components
Java Program to Find the Nearest Neighbor Using K-D Tree Search
Java TreeMap vs HashMap
How to Round a Number to N Decimal Places in Java
Custom Cascading in Spring Data MongoDB
Spring Security Basic Authentication
SOAP Web service: Authentication trong JAX-WS
Java Program to Implement Gale Shapley Algorithm
Spring Boot - Flyway Database
Làm thế nào tạo instance của một class mà không gọi từ khóa new?
Java Program to Perform Insertion in a BST
Một số từ khóa trong Java
Các kiểu dữ liệu trong java
Spring Boot - Building RESTful Web Services
Abstract class và Interface trong Java
Hướng dẫn Java Design Pattern – Strategy
Sử dụng CountDownLatch trong Java
Filtering and Transforming Collections in Guava
Query Entities by Dates and Times with Spring Data JPA
Spring – Injecting Collections
HandlerAdapters in Spring MVC
Java Program to Implement Euclid GCD Algorithm
Java Program to Implement the Hungarian Algorithm for Bipartite Matching
Java Program to Check whether Undirected Graph is Connected using BFS
Java Program to Implement Circular Doubly Linked List
Object cloning trong java
Java Program to Implement Quick Sort Using Randomization
Removing all Nulls from a List in Java
Java InputStream to String
Collection trong java
Java Program to Represent Graph Using Incidence Matrix
CharSequence vs. String in Java