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:
Java Program to Implement Depth-limited Search
@Lookup Annotation in Spring
Reactive Flow with MongoDB, Kotlin, and Spring WebFlux
Java Program to Implement DelayQueue API
Java Program to Compute Determinant of a Matrix
Updating your Password
Java Program to Implement Quick Sort with Given Complexity Constraint
Predicate trong Java 8
Spring MVC Tutorial
Java Program to Implement Shoelace Algorithm
Split a String in Java
Java Program to Implement JobStateReasons API
Jackson vs Gson
Java Program to Check if a Given Binary Tree is an AVL Tree or Not
Java Program to Find the Median of two Sorted Arrays using Binary Search Approach
Hướng dẫn Java Design Pattern – DAO
Java Program to Implement the String Search Algorithm for Short Text Sizes
Apache Camel with Spring Boot
Java Program to Find a Good Feedback Edge Set in a Graph
Tính đóng gói (Encapsulation) trong java
Optional trong Java 8
Giới thiệu SOAP UI và thực hiện test Web Service
Get the workstation name or IP
Lập trình đa luồng với CompletableFuture trong Java 8
Java Program to Implement Miller Rabin Primality Test Algorithm
Consuming RESTful Web Services
Java Program to Implement Lloyd’s Algorithm
Java Program to Give an Implementation of the Traditional Chinese Postman Problem
Using Custom Banners in Spring Boot
Java Program to Implement Stein GCD Algorithm
Spring NoSuchBeanDefinitionException
Java Program to Check the Connectivity of Graph Using BFS