pub struct UnionFind<Key: Idx> {
    table: IndexVec<Key, UnionFindEntry<Key>>,
}Expand description
Simple implementation of a union-find data structure, i.e. a disjoint-set forest.
Fields§
§table: IndexVec<Key, UnionFindEntry<Key>>Implementations§
Source§impl<Key: Idx> UnionFind<Key>
 
impl<Key: Idx> UnionFind<Key>
Sourcepub fn new(num_keys: usize) -> Self
 
pub fn new(num_keys: usize) -> Self
Creates a new disjoint-set forest containing the keys 0..num_keys.
Initially, every key is part of its own one-element set.
Sourcepub fn find(&mut self, key: Key) -> Key
 
pub fn find(&mut self, key: Key) -> Key
Returns the “root” key of the disjoint-set containing the given key. If two keys have the same root, they belong to the same set.
Also updates internal data structures to make subsequent find
operations faster.
Trait Implementations§
Auto Trait Implementations§
impl<Key> DynSend for UnionFind<Key>where
    Key: DynSend,
impl<Key> DynSync for UnionFind<Key>where
    Key: DynSync,
impl<Key> Freeze for UnionFind<Key>
impl<Key> RefUnwindSafe for UnionFind<Key>where
    Key: RefUnwindSafe,
impl<Key> Send for UnionFind<Key>where
    Key: Send,
impl<Key> Sync for UnionFind<Key>where
    Key: Sync,
impl<Key> Unpin for UnionFind<Key>where
    Key: Unpin,
impl<Key> UnwindSafe for UnionFind<Key>where
    Key: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> Instrument for T
 
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
 
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
 
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts 
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
 
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts 
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pointable for T
 
impl<T> Pointable for T
Source§impl<T> WithSubscriber for T
 
impl<T> WithSubscriber for T
Source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
 
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
Source§fn with_current_subscriber(self) -> WithDispatch<Self>
 
fn with_current_subscriber(self) -> WithDispatch<Self>
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 24 bytes