C++ Program to Check Whether an Undirected Graph Contains a Eulerian Path

This is a C++ Program to check whether an undirected graph contains Eulerian Path. 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 source code of the C++ Program to Check Whether an Undirected Graph Contains a Eulerian Path. The C++ program is successfully compiled and run on a Linux system. The program output is also shown below.

  1. // A C++ program to check if a given graph is Eulerian or not
  2. #include<iostream>
  3. #include <list>
  4. using namespace std;
  5.  
  6. // A class that represents an undirected graph
  7. class Graph
  8. {
  9.         int V; // No. of vertices
  10.         list<int> *adj; // A dynamic array of adjacency lists
  11.     public:
  12.         // Constructor and destructor
  13.         Graph(int V)
  14.         {
  15.             this->V = V;
  16.             adj = new list<int> [V];
  17.         }
  18.         ~Graph()
  19.         {
  20.             delete[] adj;
  21.         } // To avoid memory leak
  22.  
  23.         // function to add an edge to graph
  24.         void addEdge(int v, int w);
  25.  
  26.         // Method to check if this graph is Eulerian or not
  27.         int isEulerian();
  28.  
  29.         // Method to check if all non-zero degree vertices are connected
  30.         bool isConnected();
  31.  
  32.         // Function to do DFS starting from v. Used in isConnected();
  33.         void DFSUtil(int v, bool visited[]);
  34. };
  35.  
  36. void Graph::addEdge(int v, int w)
  37. {
  38.     adj[v].push_back(w);
  39.     adj[w].push_back(v); // Note: the graph is undirected
  40. }
  41.  
  42. void Graph::DFSUtil(int v, bool visited[])
  43. {
  44.     // Mark the current node as visited and print it
  45.     visited[v] = true;
  46.  
  47.     // Recur for all the vertices adjacent to this vertex
  48.     list<int>::iterator i;
  49.     for (i = adj[v].begin(); i != adj[v].end(); ++i)
  50.         if (!visited[*i])
  51.             DFSUtil(*i, visited);
  52. }
  53.  
  54. // Method to check if all non-zero degree vertices are connected.
  55. // It mainly does DFS traversal starting from
  56. bool Graph::isConnected()
  57. {
  58.     // Mark all the vertices as not visited
  59.     bool visited[V];
  60.     int i;
  61.     for (i = 0; i < V; i++)
  62.         visited[i] = false;
  63.  
  64.     // Find a vertex with non-zero degree
  65.     for (i = 0; i < V; i++)
  66.         if (adj[i].size() != 0)
  67.             break;
  68.  
  69.     // If there are no edges in the graph, return true
  70.     if (i == V)
  71.         return true;
  72.  
  73.     // Start DFS traversal from a vertex with non-zero degree
  74.     DFSUtil(i, visited);
  75.  
  76.     // Check if all non-zero degree vertices are visited
  77.     for (i = 0; i < V; i++)
  78.         if (visited[i] == false && adj[i].size() > 0)
  79.             return false;
  80.  
  81.     return true;
  82. }
  83.  
  84. /* The function returns one of the following values
  85.  0 --> If grpah is not Eulerian
  86.  1 --> If graph has an Euler path (Semi-Eulerian)
  87.  2 --> If graph has an Euler Circuit (Eulerian)  */
  88. int Graph::isEulerian()
  89. {
  90.     // Check if all non-zero degree vertices are connected
  91.     if (isConnected() == false)
  92.         return 0;
  93.  
  94.     // Count vertices with odd degree
  95.     int odd = 0;
  96.     for (int i = 0; i < V; i++)
  97.         if (adj[i].size() & 1)
  98.             odd++;
  99.  
  100.     // If count is more than 2, then graph is not Eulerian
  101.     if (odd > 2)
  102.         return 0;
  103.  
  104.     // If odd count is 2, then semi-eulerian.
  105.     // If odd count is 0, then eulerian
  106.     // Note that odd count can never be 1 for undirected graph
  107.     return (odd) ? 1 : 2;
  108. }
  109.  
  110. // Function to run test cases
  111. void test(Graph &g)
  112. {
  113.     int res = g.isEulerian();
  114.     if (res == 0)
  115.         cout << "Graph is not Eulerian\n";
  116.     else if (res == 1)
  117.         cout << "Graph has a Euler path\n";
  118.     else
  119.         cout << "Graph has a Euler cycle\n";
  120. }
  121.  
  122. // Driver program to test above function
  123. int main()
  124. {
  125.     // Let us create and test graphs shown in above figures
  126.     Graph g1(5);
  127.     g1.addEdge(1, 0);
  128.     g1.addEdge(0, 2);
  129.     g1.addEdge(2, 1);
  130.     g1.addEdge(0, 3);
  131.     g1.addEdge(3, 4);
  132.     cout<<"Result for Graph 1: ";
  133.     test(g1);
  134.  
  135.     Graph g2(5);
  136.     g2.addEdge(1, 0);
  137.     g2.addEdge(0, 2);
  138.     g2.addEdge(2, 1);
  139.     g2.addEdge(0, 3);
  140.     g2.addEdge(3, 4);
  141.     g2.addEdge(4, 0);
  142.     cout<<"Result for Graph 2: ";
  143.     test(g2);
  144.  
  145.     Graph g3(5);
  146.     g3.addEdge(1, 0);
  147.     g3.addEdge(0, 2);
  148.     g3.addEdge(2, 1);
  149.     g3.addEdge(0, 3);
  150.     g3.addEdge(3, 4);
  151.     g3.addEdge(1, 3);
  152.     cout<<"Result for Graph 3: ";
  153.     test(g3);
  154.  
  155.     // Let us create a graph with 3 vertices
  156.     // connected in the form of cycle
  157.     Graph g4(3);
  158.     g4.addEdge(0, 1);
  159.     g4.addEdge(1, 2);
  160.     g4.addEdge(2, 0);
  161.     cout<<"Result for Graph 4: ";
  162.     test(g4);
  163.  
  164.     // Let us create a graph with all veritces
  165.     // with zero degree
  166.     Graph g5(3);
  167.     cout<<"Result for Graph 5: ";
  168.     test(g5);
  169.  
  170.     return 0;
  171. }

Output:

$ g++ EulerianPathUndirected.cpp
$ a.out
 
Result for Graph 1: Graph has a Euler path
Result for Graph 2: Graph has a Euler cycle
Result for Graph 3: Graph is not Eulerian
Result for Graph 4: Graph has a Euler cycle
Result for Graph 5: Graph has a Euler cycle
 
------------------
(program exited with code: 0)
Press return to continue

Sanfoundry Global Education & Learning Series – 1000 C++ Programs.

advertisement
advertisement

Here’s the list of Best Books in C++ Programming, Data Structures and Algorithms.

If you find any mistake above, kindly email to [email protected]

advertisement
advertisement
Subscribe to our Newsletters (Subject-wise). Participate in the Sanfoundry Certification contest to get free Certificate of Merit. Join our social networks below and stay updated with latest contests, videos, internships and jobs!

Youtube | Telegram | LinkedIn | Instagram | Facebook | Twitter | Pinterest
Manish Bhojasia - Founder & CTO at Sanfoundry
Manish Bhojasia, a technology veteran with 20+ years @ Cisco & Wipro, is Founder and CTO at Sanfoundry. He lives in Bangalore, and focuses on development of Linux Kernel, SAN Technologies, Advanced C, Data Structures & Alogrithms. Stay connected with him at LinkedIn.

Subscribe to his free Masterclasses at Youtube & discussions at Telegram SanfoundryClasses.