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:
Java Program to Solve Tower of Hanoi Problem using Stacks
Java Program to Perform Stooge Sort
Spring Autowiring of Generic Types
Java Program to Implement Lloyd’s Algorithm
Java Program to Implement Suffix Array
Finding Max/Min of a List or Collection
Java Program to Give an Implementation of the Traditional Chinese Postman Problem
Adding Parameters to HttpClient Requests
Spring Boot - Google Cloud Platform
A Guide to JUnit 5
Cài đặt và sử dụng Swagger UI
Java Program to Implement AA Tree
Java Program to Implement ConcurrentHashMap API
Guava Collections Cookbook
Java Program to subtract two large numbers using Linked Lists
String Joiner trong Java 8
Java Program to Implement Stack using Two Queues
Java Program to Decode a Message Encoded Using Playfair Cipher
The Difference Between map() and flatMap()
Hướng dẫn Java Design Pattern – Mediator
Comparing Dates in Java
Từ khóa static và final trong java
Java – Try with Resources
Spring Boot Actuator
Java Program to Implement Horner Algorithm
Java Program to Implement LinkedBlockingDeque API
Jackson – Unmarshall to Collection/Array
Encode/Decode to/from Base64
Guide to Spring 5 WebFlux
Java Program to Check if a Given Set of Three Points Lie on a Single Line or Not
Spring 5 Testing with @EnabledIf Annotation
Spring Boot with Multiple SQL Import Files