3 unstable releases

Uses old Rust 2015

0.7.1 May 30, 2017
0.7.0 Apr 30, 2016
0.6.2 Apr 27, 2016

#13 in #datastructure

Download history 72/week @ 2024-09-25 58/week @ 2024-10-02 17/week @ 2024-10-09 73/week @ 2024-10-16 72/week @ 2024-10-23 71/week @ 2024-10-30 26/week @ 2024-11-06 16/week @ 2024-11-13 40/week @ 2024-11-20 59/week @ 2024-11-27 57/week @ 2024-12-04 245/week @ 2024-12-11 115/week @ 2024-12-18 13/week @ 2024-12-25 100/week @ 2025-01-01 139/week @ 2025-01-08

415 downloads per month
Used in 7 crates (3 directly)

Custom license

27KB
510 lines

IntervalTree

A simple crate that implements a interval tree datastructure. An IntervalTree maps ranges of u64 to any value. We can than use the tree to perform querys such as "what key/value pairs are intersecting the range (x,y)?" does "does the tree contain the range (X,Y)?". Insertion, deletion and lookup are in O(log(n)). Iterating over all m solutions to a query is in O(m*log(n)).

extern crate theban_interval_tree;
extern crate rand;
extern crate time;
extern crate memrange;

use memrange::Range;

fn main(){
    let data = 4221;
    let mut t = theban_interval_tree::IntervalTree::<i32>::new();

    assert!(t.empty());
    assert!{t.min().is_none()};

    t.insert(Range::new(1,1), data);
    t.insert(Range::new(2,2), data+1);
    t.insert(Range::new(3,3), data+2);

    assert_eq!{t.min().expect("get min"),(&Range::new(1,1),&data)};

    assert!(!t.empty());
    assert!(t.get_or(Range::new(1,1), &0) == &data);
    assert!(!t.contains(Range::new(0,0)));

    t.delete(Range::new(1,1));

    assert!(!t.contains(Range::new(1,1)));

    for (i,pair) in t.iter().enumerate() {
        //[...]
    }

    for (i,pair) in t.range(34, 36).enumerate() {
        //[...]
    }
}

Dependencies

~1.5MB
~27K SLoC