java.lang.Object
org.jgrapht.alg.cycle.TiernanSimpleCycles<V,E>
- Type Parameters:
V
- the vertex type.E
- the edge type.
- All Implemented Interfaces:
DirectedSimpleCycles<V,E>
public class TiernanSimpleCycles<V,E> extends java.lang.Object implements DirectedSimpleCycles<V,E>
Find all simple cycles of a directed graph using the Tiernan's algorithm.
See:
J.C.Tiernan An Efficient Search Algorithm Find the Elementary Circuits of a Graph.,
Communications of the ACM, vol.13, 12, (1970), pp. 722 - 726.
- Author:
- Nikolay Ognyanov
-
Constructor Summary
Constructors Constructor Description TiernanSimpleCycles()
Create a simple cycle finder with an unspecified graph.TiernanSimpleCycles(Graph<V,E> graph)
Create a simple cycle finder for the specified graph. -
Method Summary
-
Constructor Details
-
TiernanSimpleCycles
public TiernanSimpleCycles()Create a simple cycle finder with an unspecified graph. -
TiernanSimpleCycles
Create a simple cycle finder for the specified graph.- Parameters:
graph
- - the DirectedGraph in which to find cycles.- Throws:
java.lang.IllegalArgumentException
- if the graph argument isnull
.
-
-
Method Details
-
getGraph
Get the graph- Returns:
- graph
-
setGraph
Set the graph- Parameters:
graph
- graph
-
findSimpleCycles
Find the simple cycles of the graph.- Specified by:
findSimpleCycles
in interfaceDirectedSimpleCycles<V,E>
- Returns:
- The list of all simple cycles. Possibly empty but never
null
.
-