This is a java program to test whether a directed graph is strongly connected or not. The graph is strongly connected if it has only one connected component.
Here is the source code of the Java Program to Test Using DFS Whether a Directed Graph is Strongly Connected or Not. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
package com.maixuanviet.graph;
import java.util.*;
public class StronglyConnectedGraph
{
private int V;
private int preCount;
private int[] low;
private boolean[] visited;
private List<Integer>[] graph;
private List<List<Integer>> sccComp;
private Stack<Integer> stack;
/** function to get all strongly connected components **/
public List<List<Integer>> getSCComponents(List<Integer>[] graph)
{
V = graph.length;
this.graph = graph;
low = new int[V];
visited = new boolean[V];
stack = new Stack<Integer>();
sccComp = new ArrayList<>();
for (int v = 0; v < V; v++)
if (!visited[v])
dfs(v);
return sccComp;
}
/** function dfs **/
public void dfs(int v)
{
low[v] = preCount++;
visited[v] = true;
stack.push(v);
int min = low[v];
for (int w : graph[v])
{
if (!visited[w])
dfs(w);
if (low[w] < min)
min = low[w];
}
if (min < low[v])
{
low[v] = min;
return;
}
List<Integer> component = new ArrayList<Integer>();
int w;
do
{
w = stack.pop();
component.add(w);
low[w] = V;
}
while (w != v);
sccComp.add(component);
}
@SuppressWarnings("unchecked")
public static void main(String[] args)
{
Scanner scan = new Scanner(System.in);
System.out.println("Enter number of Vertices");
/** number of vertices **/
int V = scan.nextInt();
/** make graph **/
List<Integer>[] g = new List[V];
for (int i = 0; i < V; i++)
g[i] = new ArrayList<Integer>();
/** accept all edges **/
System.out.println("Enter number of edges");
int E = scan.nextInt();
/** all edges **/
System.out.println("Enter the edges in the graph : <from> <to>");
for (int i = 0; i < E; i++)
{
int x = scan.nextInt();
int y = scan.nextInt();
g[x].add(y);
}
StronglyConnectedGraph t = new StronglyConnectedGraph();
System.out.print("The graph is strongly connected? : ");
/** print all strongly connected components **/
List<List<Integer>> scComponents = t.getSCComponents(g);
Iterator<List<Integer>> iterator = scComponents.iterator();
boolean stronglyConnected = true;
while (iterator.hasNext())
{
if (iterator.next().size() <= 1)
{
stronglyConnected = false;
}
}
System.out.println(stronglyConnected);
scan.close();
}
}
Output:
$ javac StronglyConnectedGraph.java $ java StronglyConnectedGraph Enter number of Vertices 6 Enter number of edges 7 Enter the edges in the graph : <from> <to> 0 1 1 2 1 3 3 4 4 5 5 3 5 2 The graph is strongly connected? : false Enter number of Vertices 8 Enter number of edges 14 Enter the edges in the graph : <from> <to> 0 1 1 2 2 3 3 2 3 7 7 3 2 6 7 6 5 6 6 5 1 5 4 5 4 0 1 4 The graph is strongly connected? : true
Related posts:
Java Program to Implement Self organizing List
Jackson vs Gson
Logout in an OAuth Secured Application
Loại bỏ các phần tử trùng trong một ArrayList như thế nào trong Java 8?
Spring Security – Reset Your Password
Java Program to Find Nearest Neighbor for Static Data Set
Tránh lỗi NullPointerException trong Java như thế nào?
Java Program to Find the Longest Subsequence Common to All Sequences in a Set of Sequences
OAuth 2.0 Resource Server With Spring Security 5
Spring Boot - Cloud Configuration Client
Generate Spring Boot REST Client with Swagger
Java Program to Implement Adjacency Matrix
Java Program to Implement Bellman-Ford Algorithm
Java Program to Implement Sorted Singly Linked List
Java Program to Implement AA Tree
Java – Write to File
Java Convenience Factory Methods for Collections
Java Program to Check if a Given Set of Three Points Lie on a Single Line or Not
Từ khóa throw và throws trong Java
Java Program to Perform Quick Sort on Large Number of Elements
Java Program to Check Whether it is Weakly Connected or Strongly Connected for a Directed Graph
Java Program to Implement the Edmond’s Algorithm for Maximum Cardinality Matching
Get and Post Lists of Objects with RestTemplate
Java Program to Implement Hash Tables with Quadratic Probing
Control Structures in Java
Tránh lỗi ConcurrentModificationException trong Java như thế nào?
Tổng quan về ngôn ngữ lập trình java
Java Program to Implement the Vigenere Cypher
Spring MVC Tutorial
A Custom Data Binder in Spring MVC
Spring Data – CrudRepository save() Method
Convert String to int or Integer in Java