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:
Giới thiệu Google Guice – Injection, Scope
Java 8 StringJoiner
Loại bỏ các phần tử trùng trong một ArrayList như thế nào trong Java 8?
Working With Maps Using Streams
Java Program to Implement Affine Cipher
Java Program to Evaluate an Expression using Stacks
Java Program to Implement Knapsack Algorithm
Guide to java.util.concurrent.Future
Lập trình đa luồng với Callable và Future trong Java
Quick Guide to Spring Controllers
JUnit 5 @Test Annotation
Java Program to Use Boruvka’s Algorithm to Find the Minimum Spanning Tree
JPA/Hibernate Persistence Context
Spring Data Java 8 Support
Java Program to Implement Graham Scan Algorithm to Find the Convex Hull
Hướng dẫn Java Design Pattern – Memento
Spring Security Basic Authentication
Map Interface trong java
Adding a Newline Character to a String in Java
Java Program to Implement Segment Tree
Hashtable trong java
Introduction to Spring Data JPA
The Guide to RestTemplate
Java Program to Perform Inorder Recursive Traversal of a Given Binary Tree
How to Count Duplicate Elements in Arraylist
Giới thiệu Aspect Oriented Programming (AOP)
Guide to java.util.Formatter
Introduction to Spring Cloud OpenFeign
Java Program to Implement the MD5 Algorithm
Upload and Display Excel Files with Spring MVC
Ép kiểu trong Java (Type casting)
Java Program to Generate a Random Subset by Coin Flipping