This Java program,finds the transpose of graph matrix.In the mathematical and algorithmic study of graph theory, the converse,[1] transpose[2] or reverse[3] of a directed graph G is another directed graph on the same set of vertices with all of the edges reversed compared to the orientation of the corresponding edges in G. That is, if G contains an edge (u,v) then the converse/transpose/reverse of G contains an edge (v,u) and vice versa.
Here is the source code of the Java program to find the transpose of graph matrix. 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 TransposeOfGraph
{
private int transposeMatrix[][];
private int numberOfVertices;
public TransposeOfGraph(int numberOfVertices)
{
this.numberOfVertices = numberOfVertices;
transposeMatrix = new int[numberOfVertices + 1][numberOfVertices + 1];
}
public int[][] transpose(int adjacencyMatrix[][])
{
for (int source = 1; source <= numberOfVertices; source++)
{
for (int destination = 1; destination <= numberOfVertices; destination++)
{
transposeMatrix[destination] = adjacencyMatrix[destination];
}
}
return transposeMatrix;
}
public static void main(String... arg)
{
int number_of_nodes;
Scanner scanner = null;
System.out.println("Enter the number of nodes in the graph");
scanner = new Scanner(System.in);
number_of_nodes = scanner.nextInt();
int adjacency_matrix[][] = new int[number_of_nodes + 1][number_of_nodes + 1];
int transpose_matrix[][];
System.out.println("Enter the adjacency matrix");
for (int i = 1; i <= number_of_nodes; i++)
for (int j = 1; j <= number_of_nodes; j++)
adjacency_matrix[i][j] = scanner.nextInt();
TransposeOfGraph transposeOfGraph = new TransposeOfGraph(number_of_nodes);
transpose_matrix = transposeOfGraph.transpose(adjacency_matrix);
System.out.println("The transpose of the given graph");
for (int i = 1; i <= number_of_nodes; i++)
System.out.print("\t" + i);
System.out.println();
for (int source = 1; source <= number_of_nodes; source++)
{
System.out.print(source +"\t");
for (int destination = 1; destination <= number_of_nodes; destination++)
{
System.out.print(transpose_matrix[destination] + "\t");
}
System.out.println();
}
scanner.close();
}
}
$javac TransposeOfGraph.java $java TransposeOfGraph Enter the number of nodes in the graph 4 Enter the adjacency matrix 0 0 3 0 2 0 0 0 0 7 0 1 6 0 0 0 The transpose of the given graph 1 2 3 4 1 0 2 0 6 2 0 0 7 0 3 3 0 0 0 4 0 0 1 0
Related posts:
Guide to Dynamic Tests in Junit 5
Java Program to Implement Heap
Initialize a HashMap in Java
Spring Boot - Enabling HTTPS
Command-Line Arguments in Java
Marker Interface trong Java
Intro to the Jackson ObjectMapper
Debug a JavaMail Program
LinkedHashSet trong Java hoạt động như thế nào?
Properties with Spring and Spring Boot
Java Program to Implement Insertion Sort
Spring RestTemplate Error Handling
Tìm hiểu về Web Service
Java Program to implement Circular Buffer
Introduction to Spring Boot CLI
Sắp xếp trong Java 8
Reactive WebSockets with Spring 5
Send an email with an attachment
Lập trình đa luồng với Callable và Future trong Java
Java Program to Check if it is a Sparse Matrix
Explain about URL and HTTPS protocol
Spring WebClient vs. RestTemplate
Java Program to Print only Odd Numbered Levels of a Tree
Loại bỏ các phần tử trùng trong một ArrayList như thế nào trong Java 8?
Spring Boot - Bootstrapping
Check If a File or Directory Exists in Java
Java Program to Represent Graph Using Linked List
Hướng dẫn sử dụng String Format trong Java
Java 8 Stream findFirst() vs. findAny()
Filtering a Stream of Optionals in Java
Jackson Date
Finding Max/Min of a List or Collection