This Java program,performs the DFS traversal on the given graph represented by a adjacency matrix to find all the cross edges in a graph.the DFS traversal makes use of an stack.
Here is the source code of the Java program to find the cross 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 CrossEdge
{
private Stack<Integer> stack;
private HashMap<Integer, Integer> crossEdges;
private int adjacencyMatrix[][];
public CrossEdge()
{
stack = new Stack<Integer>();
crossEdges = 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))
{
if ( element > destination )
crossEdges.put(element, destination);
}
}
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 printCrossEdges()
{
System.out.println("\nSOURCE : DESTINATION");
Set<Integer> source = crossEdges.keySet();
for (Integer sourcevertex : source)
{
System.out.println(sourcevertex + "\t:\t"+ crossEdges.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();
CrossEdge crossEdge = new CrossEdge();
crossEdge.dfs(adjacency_matrix, source);
crossEdge.printCrossEdges();
}catch(InputMismatchException inputMismatch)
{
System.out.println("Wrong Input format");
}
scanner.close();
}
}
$javac CrossEdge.java $java CrossEdge Enter the number of nodes in the graph 5 Enter the adjacency matrix 0 1 0 1 0 0 0 1 0 0 0 0 0 0 0 0 1 0 0 1 0 0 1 0 0 Enter the source for the graph 1 The Cross Edges are SOURCE : DESTINATION 4 : 2 5 : 3
Related posts:
Finding the Differences Between Two Lists in Java
Java Program to Implement Min Heap
Java Program to Implement Sparse Array
Spring Cloud – Adding Angular
Collection trong java
New Features in Java 12
Notify User of Login From New Device or Location
Java Program to Implement ScapeGoat Tree
Java Program to Implement Hash Tree
Java Streams vs Vavr Streams
Java Program to Implement Control Table
Java Program to Implement Branch and Bound Method to Perform a Combinatorial Search
Exploring the Spring Boot TestRestTemplate
Giới thiệu Swagger – Công cụ document cho RESTfull APIs
Java Program to Compute the Area of a Triangle Using Determinants
Guide To CompletableFuture
Java Program to Remove the Edges in a Given Cyclic Graph such that its Linear Extension can be Found
Java Program to Find the Mode in a Data Set
Java Program to Use rand and srand Functions
How to Break from Java Stream forEach
Java Program to Implement Caesar Cypher
Spring AMQP in Reactive Applications
Giới thiệu JDBC Connection Pool
Java Program to Solve any Linear Equations
Guide to Selenium with JUnit / TestNG
Jackson – Unmarshall to Collection/Array
“Stream has already been operated upon or closed” Exception in Java
An Intro to Spring Cloud Security
A Guide to Java HashMap
Java Program to Implement the Vigenere Cypher
Làm thế nào tạo instance của một class mà không gọi từ khóa new?
Java Program to Implement Bubble Sort