This is a java program to test whether a directed graph is weakly connected or not. The graph is weakly connected if it has more than one connected component.
Here is the source code of the Java Program to Test Using DFS Whether a Directed Graph is Weakly Connected or Not. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
package com.sanfoundry.graph;
import java.util.*;
public class WeaklyConnectedGraph
{
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 weakly connected? : ");
/** print all strongly connected components **/
List<List<Integer>> scComponents = t.getSCComponents(g);
Iterator<List<Integer>> iterator = scComponents.iterator();
boolean weaklyConnected = false;
while (iterator.hasNext())
{
if (iterator.next().size() <= 1)
{
weaklyConnected = true;
}
}
System.out.println(weaklyConnected);
scan.close();
}
}
Output:
$ javac WeaklyConnectedGraph.java $ java WeaklyConnectedGraph 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 weakly connected? : true
Related posts:
Java Program to implement Associate Array
Upload and Display Excel Files with Spring MVC
How to Read a Large File Efficiently with Java
Spring Boot - Tomcat Deployment
Collection trong java
Spring Security Basic Authentication
Generic Constructors in Java
Java Program to find the peak element of an array using Binary Search approach
Java Program to Implement Unrolled Linked List
Java Program to Implement Skew Heap
Java – Write an InputStream to a File
Java Program to Implement Rolling Hash
Java Program to Implement Insertion Sort
Spring Boot - Creating Docker Image
Java Program to Implement AVL Tree
Spring Boot - Zuul Proxy Server and Routing
An Example of Load Balancing with Zuul and Eureka
Hướng dẫn Java Design Pattern – Flyweight
Creating Docker Images with Spring Boot
Allow user:password in URL
Assertions in JUnit 4 and JUnit 5
Spring Data JPA @Query
Java Program to Perform Polygon Containment Test
Java Program to Find Shortest Path Between All Vertices Using Floyd-Warshall’s Algorithm
Java Program to Implement an Algorithm to Find the Global min Cut in a Graph
Java TreeMap vs HashMap
Java Program to Implement Max-Flow Min-Cut Theorem
Creating a Generic Array in Java
Java Program to Use Dynamic Programming to Solve Approximate String Matching
Spring Security Custom AuthenticationFailureHandler
Spring Boot - Runners
Java Program to Implement Expression Tree