I'm looking for an algorithm to find an Euler path in a graph.
I've seen a good one a couple of weeks ago but I can't find it now, I remember there was tagging edges, something with even/odd connections...
Do you know a similar, simple and straightforward algorithm?
An euler path exists if a graph has exactly two vertices with odd degree.These are in fact the end points of the euler path.
So you can find a vertex with odd degree and start traversing the graph with DFS:As you move along have an visited array for edges.Don't traverse an edge twice.
If you there is no edge left from a vertex, check if all edges have been visited, if so you are done.
To store the actual euler path, you could keep a predecessor array, which stores previous vertex in the path.
Soo this is my solution , i've used finally block to print out because i get exception "stack is empty" and i don't really have time to fix that. I hope this helps someone!
From Graph-Magics.com, for an undirected graph, this will give you the tour in reverse order, i.e. from the end vertex to the start vertex:
Repeat step 2 until the current vertex has no more neighbors and the stack is empty.
Otherwise:
Hierholzer's algorithm is a better way to find Euler path in a directed graph.
http://stones333.blogspot.com/2013/11/find-eulerian-path-in-directed-graph.html
It has the code plus test cases.
I don't have code in any language, but I know algorithm, how to find and I'll write it here.
Suppose we have graph with n nodes. We call degree of a node number of edges connected to this node. At first we should say that sum degrees of each node would be even according to "handshake problem".
Now suppose we have some Euler path p starting from node s and ending to node f. Then for each node which is different from st and t, each time we enter that node, we should leave(if we don't leave, then we won't get to final f node), so for these nodes degree would be even, and for s and f, if they are different degree would be odd, because we left s at first time, and then after each enter, we left s node, so there would be 1 + 2*n degree where n is the number of times we visited s again. Same goes for f. So there should be 2 nodes with odd degree if there exist Euler path. And if there is Euler circle, then degree of each node should be even, and if this is the case, then it doesn't matter which node we choose as s, we will end circle in s also.
Now problem is how to get Euler circle/path. Here we need to define "bridge" in graph. Bridge is an edge with specific property, if we delete that edge, then in the remaining graph number of components would increase by one. In other words, bridge is an edge which is the only connecting edge for some two components in the graph.
Since we know what is bridge, we can define algorithm. If there exist exactly 2 nodes with even degree: 1) we start from one of them and move forward to next nodes by choosing edges connected to current node. 2) if we should choose edge between bridge and nonbridge, we should always choose nonebridge. 3) if there is node nonebridge edge left, only then we can choose any bridge.
If there is no node with odd degree, then we can start from any node and follow to those 3 rules.
That's the whole algorithm which always works. here are some useful links also.
https://www.math.ku.edu/~jmartin/courses/math105-F11/Lectures/chapter5-part2.pdf http://www.graph-magics.com/articles/euler.php