This Java program is to find all pairs shortest path.This program finds the shortest distance between every pair of vertex in the graph.
Here is the source code of the Java program to find all pairs shortest path. 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 AllPairShortestPath
{
private int distancematrix[][];
private int numberofvertices;
public static final int INFINITY = 999;
public AllPairShortestPath(int numberofvertices)
{
distancematrix = new int[numberofvertices + 1][numberofvertices + 1];
this.numberofvertices = numberofvertices;
}
public void allPairShortestPath(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");
AllPairShortestPath allPairShortestPath= new AllPairShortestPath(numberofvertices);
allPairShortestPath.allPairShortestPath(adjacency_matrix);
scan.close();
}
}
$javac AllPairShortestPath.java $java AllPairShortestPath 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:
Copy a List to Another List in Java
Java Program to Implement AttributeList API
A Guide to TreeMap in Java
Java – Try with Resources
Send an email using the SMTP protocol
Loại bỏ các phần tử trùng trong một ArrayList như thế nào trong Java 8?
Filtering a Stream of Optionals in Java
Guide to Java 8 groupingBy Collector
Java Program to find the maximum subarray sum O(n^2) time(naive method)
Java Program to Implement ArrayBlockingQueue API
Error Handling for REST with Spring
Apache Commons Collections BidiMap
Guide to the ConcurrentSkipListMap
Extract links from an HTML page
Java Program to Implement Hash Tables with Double Hashing
HashSet trong java
Java Program to Perform Search in a BST
Java Program to Implement Double Ended Queue
Java Program to Implement String Matching Using Vectors
Java Program to Implement Miller Rabin Primality Test Algorithm
An Intro to Spring Cloud Task
Disable DNS caching
Java Program to Represent Graph Using Incidence Matrix
Hướng dẫn Java Design Pattern – Mediator
Guide to WeakHashMap in Java
Tránh lỗi NullPointerException trong Java như thế nào?
Java 8 – Powerful Comparison with Lambdas
Hướng dẫn sử dụng Java Annotation
Comparing Dates in Java
Guide to CopyOnWriteArrayList
LinkedHashSet trong Java hoạt động như thế nào?
Java – Combine Multiple Collections