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:
Static Content in Spring WebFlux
Java Program to Check Cycle in a Graph using Graph traversal
Quick Guide to the Java StringTokenizer
Hướng dẫn Java Design Pattern – Object Pool
Hướng dẫn Java Design Pattern – Prototype
Spring Cloud – Adding Angular
Java Program to Implement Bit Array
Java Program to Implement Sorted Doubly Linked List
Java – InputStream to Reader
ETL with Spring Cloud Data Flow
Java Program to Implement Disjoint Set Data Structure
Spring Boot with Multiple SQL Import Files
Introduction to Spring Cloud Netflix – Eureka
Hướng dẫn Java Design Pattern – Service Locator
Ép kiểu trong Java (Type casting)
Spring Boot - Introduction
Java Program to Implement Double Order Traversal of a Binary Tree
Converting Java Date to OffsetDateTime
Batch Processing with Spring Cloud Data Flow
Mapping a Dynamic JSON Object with Jackson
Disable DNS caching
Display Auto-Configuration Report in Spring Boot
Converting String to Stream of chars
Java Program to Implement Fermat Primality Test Algorithm
Examine the internal DNS cache
Spring – Injecting Collections
Working with Tree Model Nodes in Jackson
Java Program to Implement Maximum Length Chain of Pairs
Getting Started with GraphQL and Spring Boot
Java Program to Check if it is a Sparse Matrix
Lập trình đa luồng trong Java (Java Multi-threading)
Java Program to Implement the Bin Packing Algorithm