pub trait Graph<'a, N: 'a, E> {
type NodeIterator: Iterator<Item = &'a N>;
type NeighborIterator: Iterator<Item = &'a N>;
type EdgeIterator: Iterator<Item = (&'a N, &'a N)>;
// Required methods
fn order(&self) -> usize;
fn size(&self) -> usize;
fn nodes(&'a self) -> Self::NodeIterator;
fn has_node(&self, node: &N) -> bool;
fn neighbors(&'a self, node: &N) -> Result<Self::NeighborIterator, E>;
fn degree(&self, node: &N) -> Result<usize, E>;
fn edges(&'a self) -> Self::EdgeIterator;
fn has_edge(&self, source: &N, target: &N) -> Result<bool, E>;
// Provided method
fn is_empty(&self) -> bool { ... }
}Required Associated Types§
type NodeIterator: Iterator<Item = &'a N>
type NeighborIterator: Iterator<Item = &'a N>
type EdgeIterator: Iterator<Item = (&'a N, &'a N)>
Required Methods§
Sourcefn nodes(&'a self) -> Self::NodeIterator
fn nodes(&'a self) -> Self::NodeIterator
Iterates the nodes of this graph
Sourcefn neighbors(&'a self, node: &N) -> Result<Self::NeighborIterator, E>
fn neighbors(&'a self, node: &N) -> Result<Self::NeighborIterator, E>
Iterates the neighbors of node.
Sourcefn degree(&self, node: &N) -> Result<usize, E>
fn degree(&self, node: &N) -> Result<usize, E>
Returns the number of neighbors connected to node.
Sourcefn edges(&'a self) -> Self::EdgeIterator
fn edges(&'a self) -> Self::EdgeIterator
Iterates the edges of this graph.