This Java program,performs the DFS traversal on the given graph represented by a adjacency matrix to find all the back edges in a graph.the DFS traversal makes use of an stack.
Here is the source code of the Java program to find the back Edges.The Java program is successfully compiled and run on a Linux system. The program output is also shown below.
import java.util.HashMap;
import java.util.InputMismatchException;
import java.util.Scanner;
import java.util.Set;
import java.util.Stack;
public class BackEdges
{
private Stack<Integer> stack;
private HashMap<Integer, Integer> backEdges;
private int adjacencyMatrix[][];
public BackEdges()
{
stack = new Stack<Integer>();
backEdges = new HashMap<Integer, Integer>();
}
public void dfs(int adjacency_matrix[][], int source)
{
int number_of_nodes = adjacency_matrix.length - 1;
adjacencyMatrix = new int[number_of_nodes + 1][number_of_nodes + 1];
for (int sourcevertex = 1; sourcevertex <= number_of_nodes; sourcevertex++)
{
for (int destinationvertex = 1; destinationvertex <= number_of_nodes; destinationvertex++)
{
adjacencyMatrix[sourcevertex][destinationvertex] =
adjacency_matrix[sourcevertex][destinationvertex];
}
}
int visited[] = new int[number_of_nodes + 1];
int element = source;
int destination = source;
visited = 1;
stack.push(source);
while (!stack.isEmpty())
{
element = stack.peek();
destination = element;
while (destination <= number_of_nodes)
{
if (adjacencyMatrix[element][destination] == 1 && visited[destination] == 1)
{
if (stack.contains(destination))
{
backEdges.put(element, destination);
adjacencyMatrix[element][destination]= 0;
}
}
if (adjacencyMatrix[element][destination] == 1 && visited[destination] == 0)
{
stack.push(destination);
visited[destination] = 1;
adjacencyMatrix[element][destination] = 0;
element = destination;
destination = 1;
continue;
}
destination++;
}
stack.pop();
}
}
public void printBackEdges()
{
System.out.println("\nSOURCE : DESTINATION");
Set<Integer> source = backEdges.keySet();
for (Integer sourcevertex : source)
{
System.out.println(sourcevertex + "\t:\t"+ backEdges.get(sourcevertex));
}
}
public static void main(String...arg)
{
int number_of_nodes, source;
Scanner scanner = null;
try
{
System.out.println("Enter the number of nodes in the graph");
scanner = new Scanner(System.in);
number_of_nodes = scanner.nextInt();
int adjacency_matrix[][] = new int[number_of_nodes + 1][number_of_nodes + 1];
System.out.println("Enter the adjacency matrix");
for (int i = 1; i <= number_of_nodes; i++)
for (int j = 1; j <= number_of_nodes; j++)
adjacency_matrix[i][j] = scanner.nextInt();
System.out.println("Enter the source for the graph");
source = scanner.nextInt();
BackEdges backEdges = new BackEdges();
backEdges.dfs(adjacency_matrix, source);
backEdges.printBackEdges();
}catch(InputMismatchException inputMismatch)
{
System.out.println("Wrong Input format");
}
scanner.close();
}
}
$javac BackEdges.java $java BackEdges Enter the number of nodes in the graph 4 Enter the adjacency matrix 0 1 0 0 0 0 1 0 0 0 0 1 0 1 0 0 Enter the source for the graph 1 The Back Edges are given by SOURCE : DESTINATION 4 : 2
Related posts:
Hướng dẫn Java Design Pattern – Interpreter
Converting between an Array and a List in Java
Spring Security Logout
Java Program to Implement Treap
Java Program to Find the Connected Components of an UnDirected Graph
Java Program to Implement LinkedHashMap API
Period and Duration in Java
Một số ký tự đặc biệt trong Java
Java Program to Implement Dijkstra’s Algorithm using Queue
Iterating over Enum Values in Java
Java Program to Perform Right Rotation on a Binary Search Tree
Consuming RESTful Web Services
Java Program to Implement Bloom Filter
Finding bridges in a graph in $O(N+M)$
Java Program to Describe the Representation of Graph using Incidence List
@Lookup Annotation in Spring
@DynamicUpdate with Spring Data JPA
Java equals() and hashCode() Contracts
Quick Guide to Spring MVC with Velocity
Biểu thức Lambda trong Java 8 – Lambda Expressions
Service Registration with Eureka
Xử lý ngoại lệ đối với trường hợp ghi đè phương thức trong java
Spring Boot Gradle Plugin
Java Program to Implement Fisher-Yates Algorithm for Array Shuffling
Getting Started with Stream Processing with Spring Cloud Data Flow
Spring Boot - Scheduling
Java Program to Search for an Element in a Binary Search Tree
HTTP Authentification and CGI/Servlet
Java Program to Implement Floyd Cycle Algorithm
Limiting Query Results with JPA and Spring Data JPA
Java Program to Implement Tarjan Algorithm
Java Program to Implement Direct Addressing Tables