pub struct DfsPostOrder<N, VM> {
    pub stack: Vec<N>,
    pub discovered: VM,
    pub finished: VM,
}
Expand description

Visit nodes in a depth-first-search (DFS) emitting nodes in postorder (each node after all its descendants have been emitted).

DfsPostOrder is not recursive.

The traversal starts at a given node and only traverses nodes reachable from it.

Fields§

§stack: Vec<N>

The stack of nodes to visit

§discovered: VM

The map of discovered nodes

§finished: VM

The map of finished nodes

Implementations§

Create a new DfsPostOrder using the graph’s visitor map, and put start in the stack of nodes to visit.

Create a new DfsPostOrder using the graph’s visitor map, and no stack.

Clear the visit state

Keep the discovered and finished map, but clear the visit stack and restart the dfs from a particular node.

Return the next node in the traversal, or None if the traversal is done.

Trait Implementations§

Returns a copy of the value. Read more
Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
Returns the “default value” for a type. Read more
Advance to the next item
Create an iterator out of the walker and given context.

Auto Trait Implementations§

Blanket Implementations§

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning. Read more
Uses borrowed data to replace owned data, usually by cloning. Read more
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.