Java Program to Implement Find all Cross Edges in a Graph

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:

Send email with SMTPS (eg. Google GMail)
Java – Get Random Item/Element From a List
Inject Parameters into JUnit Jupiter Unit Tests
Java Program to Implement the MD5 Algorithm
Java Program to Implement Trie
Phương thức forEach() trong java 8
Java Program to Implement Gale Shapley Algorithm
Send an email using the SMTP protocol
A Guide to Queries in Spring Data MongoDB
JWT – Token-based Authentication trong Jersey 2.x
Java Program to Implement Skip List
Mapping Nested Values with Jackson
Java Program to Show the Duality Transformation of Line and Point
Java Program to Implement Solovay Strassen Primality Test Algorithm
Chuyển đổi Array sang ArrayList và ngược lại
Java Perform to a 2D FFT Inplace Given a Complex 2D Array
Java Program to Check the Connectivity of Graph Using DFS
Java Program to Solve Travelling Salesman Problem for Unweighted Graph
Configure a Spring Boot Web Application
Java Program to Implement Circular Doubly Linked List
New Features in Java 12
Introduction to Project Reactor Bus
Java Program to Solve any Linear Equations
Java Program to Implement AttributeList API
Lớp lồng nhau trong java (Java inner class)
Jackson – JsonMappingException (No serializer found for class)
Difference Between Wait and Sleep in Java
Clique in the Divisibility Graph
Xử lý ngoại lệ đối với trường hợp ghi đè phương thức trong java
Java Program to Implement the Bin Packing Algorithm
Java Program to Implement Gift Wrapping Algorithm in Two Dimensions
Java – Rename or Move a File