This Java program, to perform the bfs traversal of a given directed graph in the form of the adjacency matrix and check for the connectivity of the graph.the bfs traversal makes use of a queue.
Here is the source code of the Java program to check the connectivity of the directed graph using BFS. 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.LinkedList;
import java.util.Queue;
import java.util.Scanner;
public class DirectedConnectivityBFS
{
private Queue<Integer> queue;
public DirectedConnectivityBFS()
{
queue = new LinkedList<Integer>();
}
public void bfs(int adjacency_matrix[][], int source)
{
int number_of_nodes = adjacency_matrix.length - 1;
int[] visited = new int[number_of_nodes + 1];
int i, element;
visited = 1;
queue.add(source);
while (!queue.isEmpty())
{
element = queue.remove();
i = element;
while (i <= number_of_nodes)
{
if (adjacency_matrix[element][i] == 1 && visited[i] == 0)
{
queue.add(i);
visited[i] = 1;
}
i++;
}
}
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_no_nodes, source;
Scanner scanner = null;
try
{
System.out.println("Enter the number of nodes in the graph");
scanner = new Scanner(System.in);
number_no_nodes = scanner.nextInt();
int adjacency_matrix[][] = new int[number_no_nodes + 1][number_no_nodes + 1];
System.out.println("Enter the adjacency matrix");
for (int i = 1; i <= number_no_nodes; i++)
for (int j = 1; j <= number_no_nodes; j++)
adjacency_matrix[i][j] = scanner.nextInt();
System.out.println("Enter the source for the graph");
source = scanner.nextInt();
DirectedConnectivityBFS directedConnectivity= new DirectedConnectivityBFS();
directedConnectivity.bfs(adjacency_matrix, source);
} catch (InputMismatchException inputMismatch)
{
System.out.println("Wrong Input Format");
}
scanner.close();
}
}
$javac DirectedConnectivityBFS.java $java DirectedConnectivityBFS Enter the number of nodes in the graph 5 Enter the adjacency matrix 0 1 1 1 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 Enter the source for the graph 1 The graph is disconnected
Related posts:
Hashing a Password in Java
@DynamicUpdate with Spring Data JPA
Java Program to Implement Flood Fill Algorithm
Lập trình đa luồng với Callable và Future trong Java
How to Convert List to Map in Java
Using Optional with Jackson
Java Program to Perform Complex Number Multiplication
OAuth 2.0 Resource Server With Spring Security 5
Spring MVC Async vs Spring WebFlux
Java Program to Solve a Matching Problem for a Given Specific Case
Guide to Guava Table
Autoboxing và Unboxing trong Java
Java – Combine Multiple Collections
String Operations with Java Streams
Spring MVC + Thymeleaf 3.0: New Features
Functional Interfaces in Java 8
Receive email using POP3
Creating Docker Images with Spring Boot
New Features in Java 13
Disable DNS caching
Introduction to Using Thymeleaf in Spring
HttpClient 4 Cookbook
Convert char to String in Java
Spring MVC Content Negotiation
Java Program to Find Nearest Neighbor for Dynamic Data Set
Java Program to Implement Ternary Heap
Command-Line Arguments in Java
Java Program to Implement Levenshtein Distance Computing Algorithm
Spring Security and OpenID Connect
Java 8 Stream API Analogies in Kotlin
Java Program to Implement Bellman-Ford Algorithm
Inheritance with Jackson