This is a Java Program to Implement Gabow Algorithm. Gabow algorithm is used for finding all strongly connected components in a graph.
Here is the source code of the Java Program to Implement Gabow Algorithm. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
/**
* Java Program to Implement Gabow Algorithm
**/
import java.util.*;
/** class Gabow **/
class Gabow
{
/** number of vertices **/
private int V;
/** preorder number counter **/
private int preCount;
private int[] preorder;
/** to check if v is visited **/
private boolean[] visited;
/** check strong componenet containing v **/
private boolean[] chk;
/** to store given graph **/
private List<Integer>[] graph;
/** to store all scc **/
private List<List<Integer>> sccComp;
private Stack<Integer> stack1;
private Stack<Integer> stack2;
/** function to get all strongly connected components **/
public List<List<Integer>> getSCComponents(List<Integer>[] graph)
{
V = graph.length;
this.graph = graph;
preorder = new int[V];
chk = new boolean[V];
visited = new boolean[V];
stack1 = new Stack<Integer>();
stack2 = 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)
{
preorder[v] = preCount++;
visited[v] = true;
stack1.push(v);
stack2.push(v);
for (int w : graph[v])
{
if (!visited[w])
dfs(w);
else if (!chk[w])
while (preorder[stack2.peek()] > preorder[w])
stack2.pop();
}
if (stack2.peek() == v)
{
stack2.pop();
List<Integer> component = new ArrayList<Integer>();
int w;
do
{
w = stack1.pop();
component.add(w);
chk[w] = true;
} while (w != v);
sccComp.add(component);
}
}
/** main **/
public static void main(String[] args)
{
Scanner scan = new Scanner(System.in);
System.out.println("Gabow algorithm Test\n");
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>();
/** accpet all edges **/
System.out.println("\nEnter number of edges");
int E = scan.nextInt();
/** all edges **/
System.out.println("Enter "+ E +" x, y coordinates");
for (int i = 0; i < E; i++)
{
int x = scan.nextInt();
int y = scan.nextInt();
g[x].add(y);
}
Gabow gab = new Gabow();
System.out.println("\nSCC : ");
/** print all strongly connected components **/
List<List<Integer>> scComponents = gab.getSCComponents(g);
System.out.println(scComponents);
}
}
Gabow algorithm Test Enter number of Vertices 8 Enter number of edges 14 Enter 14 x, y coordinates 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 SCC : [[5, 6], [7, 3, 2], [4, 1, 0]]
Related posts:
So sánh ArrayList và LinkedList trong Java
Count Occurrences of a Char in a String
Spring 5 WebClient
Giới thiệu thư viện Apache Commons Chain
Tính đa hình (Polymorphism) trong Java
SOAP Web service: Upload và Download file sử dụng MTOM trong JAX-WS
Java Program to Perform Addition Operation Using Bitwise Operators
Java Program to Implement Affine Cipher
Servlet 3 Async Support with Spring MVC and Spring Security
Java Program to Evaluate an Expression using Stacks
Java Program to Implement Cartesian Tree
Java Program to Implement the Binary Counting Method to Generate Subsets of a Set
Java Program to Implement Adjacency List
Getting a File’s Mime Type in Java
Kết hợp Java Reflection và Java Annotations
Lớp LinkedHashMap trong Java
Spring Cloud AWS – EC2
Immutable Objects in Java
Introduction to the Java NIO2 File API
Tạo ứng dụng Java RESTful Client không sử dụng 3rd party libraries
Spring @RequestMapping New Shortcut Annotations
Annotation trong Java 8
Java Program to implement Bi Directional Map
How to Get All Dates Between Two Dates?
Jackson Date
Guide to Java OutputStream
Java Program to Implement Lloyd’s Algorithm
String Joiner trong Java 8
Guide to the Fork/Join Framework in Java
Jackson JSON Views
Intro to Spring Boot Starters
Java Program to Implement Wagner and Fisher Algorithm for online String Matching