7 个版本
0.1.6 | 2024年6月21日 |
---|---|
0.1.5 | 2024年5月12日 |
#2 在 #重叠
每月397次下载
115KB
319 行
coalesced_intervals
: 维护最大合并的 1D 区间
extern crate coalesced_intervals;
fn main() {
let mut ivals = coalesced_intervals::CoalescedIntervals::new();
// Add `[0, 1)` and `[2, 3)` (there's a hole in the middle).
ivals.add(0, 1);
ivals.add(2, 3);
assert_eq!(ivals.to_vec(), [(0, 1), (2, 3)]);
// By adding `[1, 2)` we end up with a coalesced segment `[0, 3)`.
ivals.add(1, 2);
assert_eq!(ivals.to_vec(), [(0, 3)]);
// We can see that the coalesced interval has partial overlap
// with other related intervals.
assert!(ivals.contains_partial(-1, 1));
assert!(ivals.contains_partial(1, 2));
assert!(ivals.contains_partial(2, 4));
// We can ask for the interval containing some target value.
assert_eq!(ivals.get_interval_containing(1), Some((0, 3)));
assert_eq!(ivals.get_interval_containing(4), None);
// We can ask for the interval that starts at-or-after some value.
assert_eq!(ivals.get_first_start_from(-1), Some((0, 3)));
assert_eq!(ivals.get_first_start_from(0), Some((0, 3)));
assert_eq!(ivals.get_first_start_from(1), None);
}