partitions

Crates.iopartitions
lib.rspartitions
version0.2.4
sourcesrc
created_at2018-10-22 12:33:14.056919
updated_at2018-10-31 13:17:51.802143
descriptionA disjoint-sets/union-find implementation that allows for efficient iteration over elements of a set.
homepage
repositoryhttps://github.com/DDOtten/partitions.git
max_upload_size
id91970
size78,575
(DDOtten)

documentation

https://docs.rs/partitions

README

Partitions

A disjoint-sets/union-find implementation of a vector partitioned in sets that allows for efficient iteration over the elements of a set.

Latest version Documentation Average time to resolve an issue Percentage of issues still open Maintenance Build Status

The main struct of this crate is PartitionVec<T> which has the functionality of a Vec<T> and in addition divides the elements of this vector in sets. The elements each start in their own set and sets can be joined with the union method. You can check if elements share a set with the same_set method and iterate on the elements in a set with the set method. The union and same_set methods are extremely fast and have an amortized complexity of O(α(n)) where α is the inverse Ackermann function and n is the length. This complexity is proven to be optimal and α(n) has value below 5 for any n that can be written in the observable universe. The next element of the iterator returned by set is found in O(1) time.

The Disjoint-Sets algorithm is used in high-performance implementations of unification. It is also a key component in implementing Kruskal's algorithm to find the minimum spanning tree of a graph.

Using Partitions

The recommended way to use this crate is to add a line into your Cargo.toml such as:

[dependencies]
partitions = "0.2"

and then add the following to to your lib.rs or main.rs:

extern crate partitions;

License

Partitions is distributed under the terms of the Apache License (Version 2.0).

Commit count: 33

cargo fmt