Struct rpds::stack::Stack [] [src]

pub struct Stack<T> { /* fields omitted */ }

A persistent stack with structural sharing.

Complexity

Let n be the number of elements in the stack.

Temporal complexity

Operation Best case Average Worst case
new() Θ(1) Θ(1) Θ(1)
push() Θ(1) Θ(1) Θ(1)
pop() Θ(1) Θ(1) Θ(1)
peek() Θ(1) Θ(1) Θ(1)
size() Θ(1) Θ(1) Θ(1)
clone() Θ(1) Θ(1) Θ(1)
iterator creation Θ(1) Θ(1) Θ(1)
iterator step Θ(1) Θ(1) Θ(1)
iterator full Θ(n) Θ(n) Θ(n)

Implementation details

This is a thin wrapper around a List.

Methods

impl<T> Stack<T>
[src]

[src]

[src]

[src]

[src]

[src]

[src]

[src]

[src]

[src]

Trait Implementations

impl<T> Serialize for Stack<T> where
    T: Serialize
[src]

[src]

Serialize this value into the given Serde serializer. Read more

impl<'de, T> Deserialize<'de> for Stack<T> where
    T: Deserialize<'de>, 
[src]

[src]

Deserialize this value from the given Serde deserializer. Read more

impl<T: Debug> Debug for Stack<T>
[src]

[src]

Formats the value using the given formatter. Read more

impl<T> Default for Stack<T>
[src]

[src]

Returns the "default value" for a type. Read more

impl<T: PartialEq> PartialEq for Stack<T>
[src]

[src]

This method tests for self and other values to be equal, and is used by ==. Read more

1.0.0
[src]

This method tests for !=.

impl<T: Eq> Eq for Stack<T>
[src]

impl<T: PartialOrd<T>> PartialOrd<Stack<T>> for Stack<T>
[src]

[src]

This method returns an ordering between self and other values if one exists. Read more

1.0.0
[src]

This method tests less than (for self and other) and is used by the < operator. Read more

1.0.0
[src]

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more

1.0.0
[src]

This method tests greater than (for self and other) and is used by the > operator. Read more

1.0.0
[src]

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more

impl<T: Ord> Ord for Stack<T>
[src]

[src]

This method returns an Ordering between self and other. Read more

1.21.0
[src]

Compares and returns the maximum of two values. Read more

1.21.0
[src]

Compares and returns the minimum of two values. Read more

impl<T: Hash> Hash for Stack<T>
[src]

[src]

Feeds this value into the given [Hasher]. Read more

1.3.0
[src]

Feeds a slice of this type into the given [Hasher]. Read more

impl<T> Clone for Stack<T>
[src]

[src]

Returns a copy of the value. Read more

1.0.0
[src]

Performs copy-assignment from source. Read more

impl<T: Display> Display for Stack<T>
[src]

[src]

Formats the value using the given formatter. Read more

impl<'a, T> IntoIterator for &'a Stack<T>
[src]

The type of the elements being iterated over.

Which kind of iterator are we turning this into?

[src]

Creates an iterator from a value. Read more

impl<T> FromIterator<T> for Stack<T>
[src]

[src]

Creates a value from an iterator. Read more

Auto Trait Implementations

impl<T> Send for Stack<T> where
    T: Send + Sync

impl<T> Sync for Stack<T> where
    T: Send + Sync