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:
Introduction to Spring Security Expressions
Hướng dẫn sử dụng Java Reflection
Java Program to Implement Double Order Traversal of a Binary Tree
Java – Reader to String
Working with Tree Model Nodes in Jackson
Java Program to Implement Nth Root Algorithm
Java Program to Solve the Fractional Knapsack Problem
Check If a File or Directory Exists in Java
Java Program to Implement the One Time Pad Algorithm
Lớp Arrarys trong Java (Arrays Utility Class)
The Modulo Operator in Java
Jackson JSON Views
Java Program to Use Dynamic Programming to Solve Approximate String Matching
Spring Boot - Tracing Micro Service Logs
Primitive Type Streams in Java 8
Java Program to Implement Warshall Algorithm
Java Program to Implement Quick sort
Sử dụng Fork/Join Framework với ForkJoinPool trong Java
The Order of Tests in JUnit
HttpClient with SSL
Java Program to Generate N Number of Passwords of Length M Each
Java Program to Perform Arithmetic Operations on Numbers of Size
Java Program to Implement Fisher-Yates Algorithm for Array Shuffling
Guide to DelayQueue
Batch Processing with Spring Cloud Data Flow
Spring Boot - Interceptor
Deploy a Spring Boot WAR into a Tomcat Server
Hướng dẫn Java Design Pattern – DAO
Java Program to Find the Peak Element of an Array O(n) time (Naive Method)
Sử dụng CountDownLatch trong Java
Java Program to Implement Treap
Sử dụng CyclicBarrier trong Java