This Java program, represents a given graph in the incident matrix form.
Here is the source code of the Java program to represent the graph in incident matrix. The Java program is successfully compiled and run on a Linux system. The program output is also shown below.
import java.util.InputMismatchException; import java.util.Scanner; public class GraphIncidenceMatrix { private final int MAX_ROWS ; private final int MAX_COLUMS; private int Incidence_Matrix[][]; public GraphIncidenceMatrix(int number_of_vertices, int number_of_edges) { MAX_COLUMS = number_of_edges; MAX_ROWS = number_of_vertices; Incidence_Matrix = new int[MAX_ROWS + 1][MAX_COLUMS + 1]; } public void setVertices(int from_vertex, int to_vertex, int edge, int edge_num) { try { Incidence_Matrix[from_vertex][edge_num] = edge; Incidence_Matrix[to_vertex][edge_num] = edge; }catch(ArrayIndexOutOfBoundsException indexBounce) { System.out.println("the vertex entered is not present"); } } public int getVertices(int edge_num, int vertex) { try { return Incidence_Matrix[vertex][edge_num]; }catch(ArrayIndexOutOfBoundsException indexBounce) { System.out.println("the vertex entered is not present"); } return -1; } public static void main(String...arg) { int number_of_vertices; int number_of_edges; int edge_count = 1; int edge_number ; int source; int destination; GraphIncidenceMatrix incedenceMatrix = null; Scanner scan = new Scanner(System.in); try { System.out.println("Enter The Number Of Vertices and Edges \n"); number_of_vertices = scan.nextInt(); number_of_edges = scan.nextInt(); incedenceMatrix = new GraphIncidenceMatrix(number_of_vertices, number_of_edges); System.out.println("Enter the Egdes Format :<edge-number> <source index> <destination index> \n"); while (edge_count <= number_of_edges) { edge_number = scan.nextInt(); source = scan.nextInt(); destination = scan.nextInt(); edge_count++; incedenceMatrix.setVertices(source, destination, 1, edge_number); } System.out.println("The Incendence Matrix for the given graph is "); for (int i = 1; i <= number_of_edges; i++) { System.out.print("\t" + i); } System.out.println(); for (int i = 1; i <= number_of_vertices; i++) { System.out.print(i + "\t"); for (int j = 1; j<= number_of_edges; j++) { System.out.print(incedenceMatrix.getVertices(j, i) + "\t"); } System.out.println(); } }catch(InputMismatchException inputMismatch) { System.out.println("the vertex entered is not present"); } scan.close(); } }
$javac GraphIncidenceMatrix.java $java GrapIncidenceMatrix Enter The Number Of Vertices and Edges 4 5 Enter the Egdes Format :<edge-number> <source index> <destination index> 1 1 2 2 2 3 3 3 4 4 4 1 5 1 3 The Incendence Matrix for the given graph is 1 2 3 4 5 1 1 0 0 1 1 2 1 1 0 0 0 3 0 1 1 0 1 4 0 0 1 1 0
Related posts:
Circular Dependencies in Spring
Control the Session with Spring Security
Java Program to Compute Determinant of a Matrix
Jackson – Marshall String to JsonNode
Spring Boot - Interceptor
Java Program to Create a Balanced Binary Tree of the Incoming Data
Java Program to Find Nearest Neighbor for Dynamic Data Set
Spring Cloud AWS – EC2
Initialize a HashMap in Java
Autoboxing và Unboxing trong Java
Guide to Mustache with Spring Boot
Java Program to Implement Warshall Algorithm
Logging in Spring Boot
Java Program to Check whether Graph is Biconnected
Java Program to Implement Repeated Squaring Algorithm
Java Program to Generate Randomized Sequence of Given Range of Numbers
Java Program to Represent Linear Equations in Matrix Form
The StackOverflowError in Java
Java Program to Implement String Matching Using Vectors
Java Program to Check Multiplicability of Two Matrices
Java Program to Implement Sorting of Less than 100 Numbers in O(n) Complexity
Programmatic Transaction Management in Spring
Introduction to Spring Boot CLI
Java Program to Find Path Between Two Nodes in a Graph
Java Program to Perform Inorder Recursive Traversal of a Given Binary Tree
Java Program to Represent Graph Using 2D Arrays
Guide to Java 8’s Collectors
Kết hợp Java Reflection và Java Annotations
Java Program to Check whether Undirected Graph is Connected using DFS
Java Program to Perform Searching Based on Locality of Reference
Jackson Annotation Examples
An Introduction to ThreadLocal in Java