20 releases
0.8.5 | Oct 24, 2024 |
---|---|
0.8.3 | Sep 28, 2023 |
0.8.2 | Jan 4, 2023 |
0.8.1 | Nov 13, 2022 |
0.3.1 | Mar 19, 2019 |
#71 in Data structures
79,460 downloads per month
Used in 70 crates
(18 directly)
49KB
1K
SLoC
sorted_vec
Create and maintain collections of sorted elements.
let mut v = SortedVec::new();
assert_eq!(v.insert (5), 0);
assert_eq!(v.insert (3), 0);
assert_eq!(v.insert (4), 1);
assert_eq!(v.insert (4), 1);
assert_eq!(v.len(), 4);
v.dedup();
assert_eq!(v.len(), 3);
assert_eq!(v.binary_search (&3), Ok (0));
assert_eq!(*SortedVec::from_unsorted (
vec![5, -10, 99, -11, 2, 17, 10]),
vec![-11, -10, 2, 5, 10, 17, 99]);
Also provides sorted set containers only containing unique elements.
serde
support
serde
de/serialization is an optional feature.
By default, deserializing an unsorted container is an error.
To sort on deserialization, tag the field with
#[serde(deserialize_with = "SortedVec::deserialize_unsorted")]
:
#[derive(Debug, Eq, Ord, PartialEq, PartialOrd, Deserialize, Serialize)]
pub struct Foo {
#[serde(deserialize_with = "SortedVec::deserialize_unsorted")]
pub v : SortedVec <u64>
}
lib.rs
:
Sorted vectors.
SortedVec
-- sorted from least to greatest, may contain duplicatesSortedSet
-- sorted from least to greatest, unique elementsReverseSortedVec
-- sorted from greatest to least, may contain duplicatesReverseSortedSet
-- sorted from greatest to least, unique elements
The partial
module provides sorted vectors of types that only implement
PartialOrd
where comparison of incomparable elements results in runtime
panic.
Dependencies
~160KB