This is a java program to check whether graph contains Eulerian Cycle. The criteran Euler suggested,
1. If graph has no odd degree vertex, there is at least one Eulerian Circuit.
2. If graph as two vertices with odd degree, there is no Eulerian Circuit but at least one Eulerian Path.
3. If graph has more than two vertices with odd degree, there is no Eulerian Circuit or Eulerian Path.
Here is the source code of the Java Program to Check Whether an Directed Graph Contains a Eulerian Path. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
package com.maixuanviet.graph;
import java.util.InputMismatchException;
import java.util.Scanner;
public class DirectedEulerPath
{
private int[][] adjacencyMatrix;
private int numberOfNodes;
public DirectedEulerPath(int numberOfNodes, int[][] adjacencyMatrix)
{
this.numberOfNodes = numberOfNodes;
this.adjacencyMatrix = new int[numberOfNodes + 1][numberOfNodes + 1];
for (int sourceVertex = 1; sourceVertex <= numberOfNodes; sourceVertex++)
{
for (int destinationVertex = 1; destinationVertex <= numberOfNodes; destinationVertex++)
{
this.adjacencyMatrix[sourceVertex][destinationVertex] = adjacencyMatrix[sourceVertex][destinationVertex];
}
}
}
public int degree(int vertex)
{
int degree = 0;
for (int destinationvertex = 1; destinationvertex <= numberOfNodes; destinationvertex++)
{
if (adjacencyMatrix[vertex][destinationvertex] == 1
|| adjacencyMatrix[destinationvertex][vertex] == 1)
{
degree++;
}
}
return degree;
}
public int countOddDegreeVertex()
{
int count = 0;
for (int node = 1; node <= numberOfNodes; node++)
{
if ((degree(node) % 2) != 0)
{
count++;
}
}
return count;
}
public static void main(String... arg)
{
int number_of_nodes;
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();
}
}
DirectedEulerPath path = new DirectedEulerPath(number_of_nodes,
adjacency_matrix);
int count = path.countOddDegreeVertex();
if (count == 0)
{
System.out
.println("As the graph has no odd degree vertex, there is at least one Eulerian Circuit.");
}
else if (count == 2)
{
System.out
.println("As the graph as two vertices with odd degree, there is no Eulerian Circuit but at least one Eulerian Path.");
}
else
{
System.out
.println("As the graph has more than two vertices with odd degree, there is no Eulerian Circuit or Eulerian Path.");
}
}
catch (InputMismatchException inputMismatch)
{
System.out.println("Wrong Input format");
}
scanner.close();
}
}
Output:
$ javac DirectedEulerPath.java $ java DirectedEulerPath Enter the number of nodes in the graph 4 Enter the adjacency matrix 0 1 1 1 1 0 1 0 1 1 0 1 1 0 1 0 As the graph as two vertices with odd degree, there is no Eulerian Circuit but at least one Eulerian Path.
Related posts:
Using a List of Values in a JdbcTemplate IN Clause
Spring 5 and Servlet 4 – The PushBuilder
Java Program to Find Nearest Neighbor for Dynamic Data Set
Java – Write a Reader to File
Intro to the Jackson ObjectMapper
Simplify the DAO with Spring and Java Generics
Hướng dẫn sử dụng Printing Service trong Java
Arrays.asList vs new ArrayList(Arrays.asList())
Java Program to Perform Deletion in a BST
OAuth2.0 and Dynamic Client Registration
Marker Interface trong Java
Java Program to Perform Complex Number Multiplication
Class Loaders in Java
Handling URL Encoded Form Data in Spring REST
Getting Started with Stream Processing with Spring Cloud Data Flow
Java Program to Use rand and srand Functions
Unsatisfied Dependency in Spring
Java Program to Check whether Graph is a Bipartite using DFS
Java Program to Apply Above-Below-on Test to Find the Position of a Point with respect to a Line
Spring – Injecting Collections
Spring Data JPA @Modifying Annotation
Write/Read cookies using HTTP and Read a file from the internet
A Custom Data Binder in Spring MVC
Java Program to Implement LinkedBlockingQueue API
Spring Boot - Hystrix
Java Program to Find Minimum Element in an Array using Linear Search
Java Program to Implement RoleList API
Java Program to Implement RoleUnresolvedList API
Jackson Unmarshalling JSON with Unknown Properties
New Features in Java 8
Java Program to Implement Coppersmith Freivald’s Algorithm
Java Program to Implement Adjacency List