29(March) Euler Circuit in an Undirected Graph
29. Euler Circuit in an Undirected Graph
The problem can be found at the following link: Question Link
Problem Description
Given the number of vertices v and an adjacency list adj denoting a directed graph, determine whether there exists an Eulerian circuit in the graph. An Eulerian circuit is a path in a graph that visits every edge exactly once and starts and ends at the same vertex.
Example:
Input:
v = 4
edges[] = {{0, 1},
           {0, 2},
           {1, 3},
           {2, 3}}Output:
1Explanation: One of the Eulerian circuits starting from vertex 0 is as follows: 0 -> 1 -> 3 -> 2 -> 0
My Approach
- Checking for Eulerian Circuit Existence: - Iterate through each vertex in the graph. 
- Check if the degree of each vertex is even. If any vertex has an odd degree, return false indicating that there is no Eulerian circuit. 
 
- Return Result: - If all vertices have even degrees, return true indicating the existence of an Eulerian circuit. 
 
Time and Auxiliary Space Complexity
- Expected Time Complexity: O(v + e), where - vis the number of vertices and- eis the number of edges in the graph.
- Expected Auxiliary Space Complexity: O(v), where - vis the number of vertices, for storing the degree of each vertex.
Code (C++)
class Solution {
public:
    bool isEularCircuitExist(int v, vector<int> adj[]) {
        for (int i = 0; i < v; i++) {
            if (adj[i].size() % 2 != 0) {
                return false;
            }
        }
        return true;
    }
};Contribution and Support
For discussions, questions, or doubts related to this solution, feel free to connect on LinkedIn: Any Questions. Let’s make this learning journey more collaborative!
⭐ If you find this helpful, please give this repository a star! ⭐
📍Visitor Count
Last updated