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:

Java Program to implement Associate Array
Spring RestTemplate Error Handling
Quick Intro to Spring Cloud Configuration
Getting a File’s Mime Type in Java
Spring Security Logout
Java Program to Implement Sorting of Less than 100 Numbers in O(n) Complexity
Java Program to Implement Solovay Strassen Primality Test Algorithm
An Intro to Spring Cloud Contract
Updating your Password
Java Program to Solve TSP Using Minimum Spanning Trees
Java Concurrency Interview Questions and Answers
Java Program to Generate Random Partition out of a Given Set of Numbers or Characters
Java Program to Implement Suffix Array
Hướng dẫn Java Design Pattern – Command
Mix plain text and HTML content in a mail
Java Program to Compute Discrete Fourier Transform Using the Fast Fourier Transform Approach
Java – Byte Array to Reader
Hướng dẫn sử dụng Java String, StringBuffer và StringBuilder
String Processing with Apache Commons Lang 3
Creating a Custom Starter with Spring Boot
Concatenating Strings In Java
Java Program to Implement Hash Tables
Java Program to Implement Merge Sort on n Numbers Without tail-recursion
Converting String to Stream of chars
Java Program to Find SSSP (Single Source Shortest Path) in DAG (Directed Acyclic Graphs)
Java Program to Compute the Area of a Triangle Using Determinants
Java Program to Implement Ternary Search Algorithm
Java Program to do a Depth First Search/Traversal on a graph non-recursively
Java Program to Perform Preorder Non-Recursive Traversal of a Given Binary Tree
Spring MVC Custom Validation
Spring Security with Maven
Spring Data JPA @Query