pub struct Matching<G: GraphBase> { /* private fields */ }
Expand description
Computed matching of the graph.
Implementations§
source§impl<G> Matching<G>where
G: NodeIndexable,
impl<G> Matching<G>where
G: NodeIndexable,
sourcepub fn mate(&self, node: G::NodeId) -> Option<G::NodeId>
pub fn mate(&self, node: G::NodeId) -> Option<G::NodeId>
Gets the matched counterpart of given node, if there is any.
Returns None
if the node is not matched or does not exist.
sourcepub fn edges(&self) -> MatchedEdges<'_, G> ⓘ
pub fn edges(&self) -> MatchedEdges<'_, G> ⓘ
Iterates over all edges from the matching.
An edge is represented by its endpoints. The graph is considered undirected and every pair of matched nodes is reported only once.
sourcepub fn nodes(&self) -> MatchedNodes<'_, G> ⓘ
pub fn nodes(&self) -> MatchedNodes<'_, G> ⓘ
Iterates over all nodes from the matching.
sourcepub fn contains_edge(&self, a: G::NodeId, b: G::NodeId) -> bool
pub fn contains_edge(&self, a: G::NodeId, b: G::NodeId) -> bool
Returns true
if given edge is in the matching, or false
otherwise.
If any of the the nodes does not exist, false
is returned.
sourcepub fn contains_node(&self, node: G::NodeId) -> bool
pub fn contains_node(&self, node: G::NodeId) -> bool
Returns true
if given node is in the matching, or false
otherwise.
If the node does not exist, false
is returned.