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:
Java Program to Implement Merge Sort on n Numbers Without tail-recursion
Implementing a Runnable vs Extending a Thread
Spring Data Java 8 Support
Hướng dẫn sử dụng Java String, StringBuffer và StringBuilder
Injecting Prototype Beans into a Singleton Instance in Spring
Removing all Nulls from a List in Java
Java Program to Implement TreeMap API
Spring Security OAuth Login with WebFlux
Spring Boot - Cloud Configuration Client
Java Program to Implement Fenwick Tree
Lập trình đa luồng với CompletableFuture trong Java 8
Java Program to Implement Ford–Fulkerson Algorithm
Java Program to Find the Nearest Neighbor Using K-D Tree Search
Introduction to Spliterator in Java
Performance Difference Between save() and saveAll() in Spring Data
Inheritance with Jackson
Sử dụng CyclicBarrier trong Java
Spring Boot - Apache Kafka
Java Program to Check for balanced parenthesis by using Stacks
Stack Memory and Heap Space in Java
Java Program to Implement Slicker Algorithm that avoids Triangulation to Find Area of a Polygon
Java Program to Implement PriorityQueue API
Java Program to Perform Preorder Non-Recursive Traversal of a Given Binary Tree
Java Program to Find Nearest Neighbor for Static Data Set
Custom Error Pages with Spring MVC
So sánh HashSet, LinkedHashSet và TreeSet trong Java
The SpringJUnitConfig and SpringJUnitWebConfig Annotations in Spring 5
Setting the Java Version in Maven
Sử dụng Fork/Join Framework với ForkJoinPool trong Java
Java Program to Implement the Bin Packing Algorithm
Guide To CompletableFuture
Mệnh đề Switch-case trong java