17 releases
0.3.7 | Oct 18, 2024 |
---|---|
0.3.6 | Jun 12, 2023 |
0.3.5 | May 21, 2023 |
0.3.4 | Aug 19, 2022 |
0.2.1 | Nov 20, 2020 |
#105 in Data structures
222,196 downloads per month
Used in 338 crates
(5 directly)
74KB
888 lines
dary_heap
Rust implementation of a d-ary heap. The d = 2 version is present in
the standard library as BinaryHeap
, but using a higher value
for d can bring performance improvements in many use cases. This is because a
higher arity d (maximum number of children each node can have) means the heap
contains less layers, making adding elements to the heap faster. However,
removing elements is slower, because then the amount of work per layer is higher
as there are more children. The latter effect is often diminished due to higher
cache locality. Therefore, overall performance is often increased if d > 2 but
not too high. Benchmarking is necessary to determine the best value of d for a
specific use case.
Compatibility and stability
The API of this crate aims to be analogous to that of BinaryHeap
in the
standard library. Feature-gated API in the standard library is
also feature-gated in dary_heap
, see the section on features for
more information. In fact, the code in dary_heap
is directly based on that of
the standard library. The BinaryHeap
provided by this crate should therefore
provide similar performance as that of the standard library, and the other heap
types provided by this crate may provide performance improvements.
The version of the standard library this crate is based on is currently 1.82.0. The aim is to keep the crate in sync with the latest stable Rust release.
The minimum supported Rust version (MSRV) is currently 1.51.0. The last version without const generics has a MSRV of 1.31.0 and is being maintained on the non-const-generics branch of this repository.
The MSRV can be increased in a minor level release, but not in a patch level release.
There are no stability guarantees for the unstable
and unstable_nightly
features. Changes to the behavior of nullary heaps (that should not be used
anyway) are also not considered to be breaking and can happen in a patch level
release.
Features
extra
: add features that require a higher MSRV (currently 1.61.0).- add
shrink_to
method to shrink heap capacity to a lower bound. - add
try_reserve
method to try to reserve additional capacity in the heap. - add
try_reserve_exact
method to try to reserve minimal additonal capacity. - make
new
methodconst
.
- add
serde
: add support for (de)serialization using Serde.unstable
: enable support for experimental (unstable) features:- add
drain_sorted
method which is likedrain
but yields elements in heap order. - add
into_iter_sorted
method which is likeinto_iter
but yields elements in heap order.
- add
unstable_nightly
: enable support for experimental (unstable) features that require a nightly Rust compiler:- implement methods defined by unstable feature
exact_size_is_empty
onExactSizeIterator
s in this crate. - implement methods defined by unstable feature
extend_one
. - implement
SourceIter
andInPlaceIterable
forIntoIter
. - implement
TrustedLen
for iterators if possible (only whenunstable
is also enabled).
- implement methods defined by unstable feature
License
dary_heap
is licensed under either of
- Apache License, Version 2.0 (LICENSE-APACHE or https://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or https://opensource.org/licenses/MIT)
at your option.
Dependencies
~160KB