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

#1865 in Data structures

Download history 115/week @ 2023-11-23 67/week @ 2023-11-30 76/week @ 2023-12-07 113/week @ 2023-12-14 107/week @ 2023-12-21 41/week @ 2023-12-28 80/week @ 2024-01-04 136/week @ 2024-01-11 99/week @ 2024-01-18 80/week @ 2024-01-25 52/week @ 2024-02-01 99/week @ 2024-02-08 140/week @ 2024-02-15 118/week @ 2024-02-22 102/week @ 2024-02-29 101/week @ 2024-03-07

488 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.2–1.5MB
~25K SLoC