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