Package org.jgrapht.alg.connectivity
Class KosarajuStrongConnectivityInspector<V,E>
- java.lang.Object
-
- org.jgrapht.alg.connectivity.KosarajuStrongConnectivityInspector<V,E>
-
- Type Parameters:
V- the graph vertex typeE- the graph edge type
- All Implemented Interfaces:
StrongConnectivityAlgorithm<V,E>
public class KosarajuStrongConnectivityInspector<V,E> extends java.lang.ObjectComputes strongly connected components of a directed graph. The algorithm is implemented after "Cormen et al: Introduction to algorithms", Chapter 22.5. It has a running time of $O(V + E)$.Unlike
ConnectivityInspector, this class does not implement incremental inspection. The full algorithm is executed at the first call ofstronglyConnectedSets()orStrongConnectivityAlgorithm.isStronglyConnected().- Author:
- Christian Soltenborn, Christian Hammer
-
-
Field Summary
Fields Modifier and Type Field Description protected Graph<V,E>graphprotected java.util.List<java.util.Set<V>>stronglyConnectedSetsprotected java.util.List<Graph<V,E>>stronglyConnectedSubgraphs
-
Constructor Summary
Constructors Constructor Description KosarajuStrongConnectivityInspector(Graph<V,E> graph)Constructor
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description Graph<Graph<V,E>,DefaultEdge>getCondensation()Compute the condensation of the given graph.Graph<V,E>getGraph()Return the underlying graph.java.util.List<Graph<V,E>>getStronglyConnectedComponents()Computes a list of subgraphs of the given graph.booleanisStronglyConnected()Returns true if the graph is strongly connected, false otherwise.java.util.List<java.util.Set<V>>stronglyConnectedSets()Computes aListofSets, where each set contains vertices which together form a strongly connected component within the given graph.
-
-
-
Method Detail
-
stronglyConnectedSets
public java.util.List<java.util.Set<V>> stronglyConnectedSets()
Description copied from interface:StrongConnectivityAlgorithmComputes aListofSets, where each set contains vertices which together form a strongly connected component within the given graph.- Returns:
ListofSets containing the strongly connected components
-
getGraph
public Graph<V,E> getGraph()
Description copied from interface:StrongConnectivityAlgorithmReturn the underlying graph.- Specified by:
getGraphin interfaceStrongConnectivityAlgorithm<V,E>- Returns:
- the underlying graph
-
isStronglyConnected
public boolean isStronglyConnected()
Description copied from interface:StrongConnectivityAlgorithmReturns true if the graph is strongly connected, false otherwise.- Specified by:
isStronglyConnectedin interfaceStrongConnectivityAlgorithm<V,E>- Returns:
- true if the graph is strongly connected, false otherwise
-
getStronglyConnectedComponents
public java.util.List<Graph<V,E>> getStronglyConnectedComponents()
Description copied from interface:StrongConnectivityAlgorithmComputes a list of subgraphs of the given graph. Each subgraph will represent a strongly connected component and will contain all vertices of that component. The subgraph will have an edge $(u,v)$ iff $u$ and $v$ are contained in the strongly connected component.- Specified by:
getStronglyConnectedComponentsin interfaceStrongConnectivityAlgorithm<V,E>- Returns:
- a list of subgraphs representing the strongly connected components
-
getCondensation
public Graph<Graph<V,E>,DefaultEdge> getCondensation()
Description copied from interface:StrongConnectivityAlgorithmCompute the condensation of the given graph. If each strongly connected component is contracted to a single vertex, the resulting graph is a directed acyclic graph, the condensation of the graph.- Specified by:
getCondensationin interfaceStrongConnectivityAlgorithm<V,E>- Returns:
- the condensation of the given graph
-
-