This is a Java Program to Implement Tarjan Algorithm. Tarjan Algorithm is used for finding all strongly connected components in a graph.
Here is the source code of the Java Program to Implement Tarjan Algorithm. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
/**
* Java Program to Implement Tarjan Algorithm
**/
import java.util.*;
/** class Tarjan **/
class Tarjan
{
/** number of vertices **/
private int V;
/** preorder number counter **/
private int preCount;
/** low number of v **/
private int[] low;
/** to check if v is visited **/
private boolean[] visited;
/** to store given graph **/
private List<Integer>[] graph;
/** to store all scc **/
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);
}
/** main **/
public static void main(String[] args)
{
Scanner scan = new Scanner(System.in);
System.out.println("Tarjan 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);
}
Tarjan t = new Tarjan();
System.out.println("\nSCC : ");
/** print all strongly connected components **/
List<List<Integer>> scComponents = t.getSCComponents(g);
System.out.println(scComponents);
}
}
Tarjan 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:
OAuth2 for a Spring REST API – Handle the Refresh Token in AngularJS
Java Program to Implement Sorted Circular Doubly Linked List
Java Program to Implement Euler Circuit Problem
Tạo ứng dụng Java RESTful Client với thư viện Retrofit
Spring Boot - Rest Template
Lớp Arrarys trong Java (Arrays Utility Class)
Working With Maps Using Streams
Introduction to PCollections
New Features in Java 11
Java Program to Check whether Directed Graph is Connected using BFS
Introduction to Spring Data JDBC
Sử dụng CountDownLatch trong Java
Converting a Stack Trace to a String in Java
Serialize Only Fields that meet a Custom Criteria with Jackson
Java Program to implement Dynamic Array
Java Program to Find Second Smallest of n Elements with Given Complexity Constraint
Java Program to Implement Queue using Linked List
An Introduction to ThreadLocal in Java
Java Program to Implement SimpeBindings API
Intro to the Jackson ObjectMapper
Spring Cloud – Securing Services
Java Program to Implement Stein GCD Algorithm
Hướng dẫn Java Design Pattern – Null Object
Java Program to Check if a Given Graph Contain Hamiltonian Cycle or Not
So sánh HashMap và HashSet trong Java
XML-Based Injection in Spring
Setting Up Swagger 2 with a Spring REST API
Loại bỏ các phần tử trùng trong một ArrayList như thế nào trong Java 8?
Receive email using IMAP
Guide to DelayQueue
Giới thiệu HATEOAS
Java Program to Find Strongly Connected Components in Graphs