This Java program,performs the DFS traversal on the given directed graph represented by a adjacency matrix to check connectivity.the DFS traversal makes use of an stack.
Here is the source code of the Java program to check the connectivity of a directed graph. 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; import java.util.Stack; public class DirectedConnectivityDfs { private Stack<Integer> stack; public DirectedConnectivityDfs() { stack = new Stack<Integer>(); } public void dfs(int adjacency_matrix[][], int source) { int number_of_nodes = adjacency_matrix.length - 1; int visited[] = new int[number_of_nodes + 1]; int element = source; int i = source; visited = 1; stack.push(source); while (!stack.isEmpty()) { element = stack.peek(); i = element; while (i <= number_of_nodes) { if (adjacency_matrix[element][i] == 1 && visited[i] == 0) { stack.push(i); visited[i] = 1; element = i; i = 1; continue; } i++; } stack.pop(); } boolean connected = false; for (int vertex = 1; vertex <= number_of_nodes; vertex++) { if (visited[vertex] == 1) { connected = true; } else { connected = false; break; } } if (connected) { System.out.println("The graph is connected"); }else { System.out.println("The graph is disconnected"); } } public static void main(String...arg) { int number_of_nodes, source; Scanner scanner = null; try { 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]; 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(); System.out.println("Enter the source for the graph"); source = scanner.nextInt(); DirectedConnectivityDfs directedConnectivity= new DirectedConnectivityDfs(); directedConnectivity.dfs(adjacency_matrix, source); }catch(InputMismatchException inputMismatch) { System.out.println("Wrong Input format"); } scanner.close(); } }
$javac DirectedConnectivityDfs.java $java DirectedConnectivityDfs Enter the number of nodes in the graph 5 Enter the adjacency matrix 0 1 0 1 0 0 0 1 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 Enter the source for the graph 1 The graph is disconnected
Related posts:
Java Switch Statement
JUnit5 Programmatic Extension Registration with @RegisterExtension
A Guide to the Java ExecutorService
Java Program to Decode a Message Encoded Using Playfair Cipher
Hướng dẫn Java Design Pattern – Builder
Java Program to Implement Circular Singly Linked List
Guide to Escaping Characters in Java RegExps
“Stream has already been operated upon or closed” Exception in Java
Java Program to Perform the Shaker Sort
Concurrent Test Execution in Spring 5
ClassNotFoundException vs NoClassDefFoundError
Java Program to Perform Quick Sort on Large Number of Elements
@DynamicUpdate with Spring Data JPA
A Guide to BitSet in Java
Custom Exception trong Java
Command-Line Arguments in Java
Kiểu dữ liệu Ngày Giờ (Date Time) trong java
Receive email by java client
Java Program to Perform Insertion in a BST
Convert Hex to ASCII in Java
Calling Stored Procedures from Spring Data JPA Repositories
Java Program to add two large numbers using Linked List
Toán tử instanceof trong java
Abstract class và Interface trong Java
OAuth2 Remember Me with Refresh Token
Java Program to Construct K-D Tree for 2 Dimensional Data
Vấn đề Nhà sản xuất (Producer) – Người tiêu dùng (Consumer) và đồng bộ hóa các luồng trong Java
Java Program to Implement Weight Balanced Tree
Weak References in Java
Automatic Property Expansion with Spring Boot
Retrieve User Information in Spring Security
Working With Maps Using Streams