Interface CyclesEnumerator

  • All Known Implementing Classes:
    CyclesEnumeratorAbstract, CyclesEnumeratorJohnson, CyclesEnumeratorTarjan

    public interface CyclesEnumerator
    An algorithm that enumerate all cycles in a graph.

    Given a graph G=(V,E), a cycle is a path P=(v1,v2,,vk),viV,(vi,vi+1)E such that v1=vk. There might be exponentially many cycles in a graph, and algorithms implementing this interface enumerate over all of them (use an Iterator avoiding storing all of them in memory).

    Use newInstance() to get a default implementation of this interface.

    Author:
    Barak Ugav
    • Method Detail

      • cyclesIter

        <V,​E> Iterator<Path<V,​E>> cyclesIter​(Graph<V,​E> g)
        Iterate over all cycles in the given graph.

        If g is IntGraph, the returned iterator will iterate over IPath objects.

        Type Parameters:
        V - the vertices type
        E - the edges type
        Parameters:
        g - a graph
        Returns:
        an iterator that iteration over all cycles in the graph