ResizingBag

Struct ResizingBag 

Source
pub struct ResizingBag<T> { /* private fields */ }
Expand description

A bag (or multiset) of generic items.

It supports insertion and iterating over the items in arbitrary order.

This implementation uses an SVec. Substituting std::vec::Vec for SVec also works. ResizingBag is similar to algs4 Java version ResizingArrayBag. See crate::LinkedBag for a version that uses a linked list.

The add, is_empty, and size operations take constant time. Iteration takes time proportional to the number of items.

For additional documentation, see Section 1.3 of Algorithms, 4th Edition by Robert Sedgewick and Kevin Wayne.

Implementations§

Source§

impl<T> ResizingBag<T>

Source

pub fn new() -> Self

Initializes an empty bag.

Source

pub fn is_empty(&self) -> bool

Returns true if this bag is empty, returns false otherwise.

Source

pub fn len(&self) -> usize

Returns the number of items in this bag.

Source

pub fn add(&mut self, item: T)

Adds the item to this bag.

Source

pub fn iter(&self) -> ResizingBagIter<'_, T>

Returns an iterator that iterates over the items in this bag in arbitrary order.

Trait Implementations§

Source§

impl<T: Clone> Clone for ResizingBag<T>

Source§

fn clone(&self) -> ResizingBag<T>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T> Default for ResizingBag<T>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl<T> Freeze for ResizingBag<T>

§

impl<T> RefUnwindSafe for ResizingBag<T>
where T: RefUnwindSafe,

§

impl<T> Send for ResizingBag<T>
where T: Send,

§

impl<T> Sync for ResizingBag<T>
where T: Sync,

§

impl<T> Unpin for ResizingBag<T>

§

impl<T> UnwindSafe for ResizingBag<T>
where T: RefUnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

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

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.