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:
A Guide to EnumMap
Logout in an OAuth Secured Application
Java Program to Generate Random Numbers Using Middle Square Method
Introduction to Spring Cloud Netflix – Eureka
Tính trừu tượng (Abstraction) trong Java
Jackson Unmarshalling JSON with Unknown Properties
Java Program to Print the Kind of Rotation the AVL Tree is Undergoing
Java Program to Implement Interpolation Search Algorithm
Iterating over Enum Values in Java
Converting a Stack Trace to a String in Java
Batch Processing with Spring Cloud Data Flow
Sorting Query Results with Spring Data
Hashtable trong java
Introduction to the Functional Web Framework in Spring 5
Hướng dẫn Java Design Pattern – Abstract Factory
Java Program to Perform Insertion in a BST
Java Program to Permute All Letters of an Input String
Java Program to Implement Park-Miller Random Number Generation Algorithm
Array to String Conversions
Java Program to Generate a Sequence of N Characters for a Given Specific Case
Java Program to Generate a Random UnDirected Graph for a Given Number of Edges
Java Program to Implement Euclid GCD Algorithm
Java Program to Implement the Monoalphabetic Cypher
Ways to Iterate Over a List in Java
Merging Two Maps with Java 8
Java Program to Solve the Fractional Knapsack Problem
Guide to java.util.concurrent.BlockingQueue
Inheritance and Composition (Is-a vs Has-a relationship) in Java
Hướng dẫn Java Design Pattern – Mediator
Java Program to Implement a Binary Search Algorithm for a Specific Search Sequence
Java – Reader to String
A Guide to JUnit 5