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 Spring 5 WebFlux
A Guide to Java SynchronousQueue
Spring Boot: Customize the Jackson ObjectMapper
Java Program to Implement Knapsack Algorithm
How to Set TLS Version in Apache HttpClient
Check if a String is a Palindrome in Java
Apache Commons Collections Bag
Java Program to Find MST (Minimum Spanning Tree) using Prim’s Algorithm
Serve Static Resources with Spring
JUnit5 Programmatic Extension Registration with @RegisterExtension
Giới thiệu thư viện Apache Commons Chain
Spring Autowiring of Generic Types
Quick Guide to the Java StringTokenizer
OAuth2 for a Spring REST API – Handle the Refresh Token in AngularJS
Java Program to Implement Hamiltonian Cycle Algorithm
Java Program to find the number of occurrences of a given number using Binary Search approach
Java Program to Implement Singly Linked List
Custom Exception trong Java
So sánh HashMap và HashSet trong Java
Java Program to Generate All Possible Subsets with Exactly k Elements in Each Subset
Java Program to Implement Pagoda
Java Program to Find the Edge Connectivity of a Graph
Guide to the Volatile Keyword in Java
Java Program to Find Transitive Closure of a Graph
How to Store Duplicate Keys in a Map in Java?
Comparing Long Values in Java
Java Program to Construct an Expression Tree for an Postfix Expression
Sort a HashMap in Java
Spring REST API with Protocol Buffers
Guide to java.util.concurrent.BlockingQueue
Map to String Conversion in Java
Giới thiệu Google Guice – Dependency injection (DI) framework