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 Perform Inorder Non-Recursive Traversal of a Given Binary Tree
Java Program to implement Bi Directional Map
Java Program to Perform Finite State Automaton based Search
Guide to the Fork/Join Framework in Java
Spring Boot Tutorial – Bootstrap a Simple Application
Easy Ways to Write a Java InputStream to an OutputStream
Java Program to Find Transpose of a Graph Matrix
Overview of the java.util.concurrent
Java Program to Implement Gabow Algorithm
Java Program to Implement the MD5 Algorithm
Java Program to Implement the Binary Counting Method to Generate Subsets of a Set
Java Program to Implement the Alexander Bogomolny’s UnOrdered Permutation Algorithm for Elements Fro...
Java Program to Find Transitive Closure of a Graph
Java Program to Describe the Representation of Graph using Incidence Matrix
Pagination and Sorting using Spring Data JPA
Hướng dẫn sử dụng String Format trong Java
Java Program to Check Whether an Undirected Graph Contains a Eulerian Path
Java Program to Implement Doubly Linked List
Java Program to Implement Circular Singly Linked List
Java Program to Implement Booth Algorithm
Spring Boot - OAuth2 with JWT
Java Program to Check Whether an Input Binary Tree is the Sub Tree of the Binary Tree
Spring RequestMapping
Spring Data MongoDB Transactions
Java Program to Implement EnumMap API
Java Program to Construct K-D Tree for 2 Dimensional Data
Filtering a Stream of Optionals in Java
Overflow and Underflow in Java
Java Program to Represent Graph Using Linked List
Java Program to Generate Random Partition out of a Given Set of Numbers or Characters
Guide to Spring Cloud Kubernetes
Java Program to Implement Depth-limited Search