This Java program is to implement the Floyd-Warshall algorithm.The algorithm is a graph analysis algorithm for finding shortest paths in a weighted graph with positive or negative edge weights (but with no negative cycles) and also for finding transitive closure of a relation R.
Here is the source code of the Java program to implement Floyd-Warshall algorithm. 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 FloydWarshall
{
private int distancematrix[][];
private int numberofvertices;
public static final int INFINITY = 999;
public FloydWarshall(int numberofvertices)
{
distancematrix = new int[numberofvertices + 1][numberofvertices + 1];
this.numberofvertices = numberofvertices;
}
public void floydwarshall(int adjacencymatrix[][])
{
for (int source = 1; source <= numberofvertices; source++)
{
for (int destination = 1; destination <= numberofvertices; destination++)
{
distancematrix[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 (distancematrix[intermediate] + distancematrix[intermediate][destination]
< distancematrix[destination])
distancematrix[destination] = distancematrix[intermediate]
+ distancematrix[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(distancematrix[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");
FloydWarshall floydwarshall = new FloydWarshall(numberofvertices);
floydwarshall.floydwarshall(adjacency_matrix);
scan.close();
}
}
$javac FloydWarshall.java $java FloydWarshall 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 Solve Knapsack Problem Using Dynamic Programming
Explain about URL and HTTPS protocol
Life Cycle of a Thread in Java
Tổng quan về ngôn ngữ lập trình java
Java Program to Describe the Representation of Graph using Incidence List
Versioning a REST API
Giới thiệu HATEOAS
Spring Boot - Securing Web Applications
Enum trong java
Spring Boot Gradle Plugin
Server-Sent Events in Spring
Java Program to Construct an Expression Tree for an Infix Expression
Java Program to Implement Binary Heap
Java Program to Perform Addition Operation Using Bitwise Operators
Java Program to Check if a Directed Graph is a Tree or Not Using DFS
Jackson vs Gson
A Guide to HashSet in Java
Spring Boot - Flyway Database
HttpClient Connection Management
Spring Boot - Admin Server
How to Read HTTP Headers in Spring REST Controllers
Java Program to Find Minimum Element in an Array using Linear Search
Java Web Services – JAX-WS – SOAP
Java Program to Find the Longest Path in a DAG
Spring – Injecting Collections
Java Program to Implement Miller Rabin Primality Test Algorithm
Java – Reader to String
Java Program to Implement TreeMap API
Spring Boot Security Auto-Configuration
Guide to CountDownLatch in Java
Spring Boot - Rest Controller Unit Test
The HttpMediaTypeNotAcceptableException in Spring MVC