21 releases

0.8.0 Sep 18, 2024
0.7.1 Apr 15, 2023
0.6.2 Feb 11, 2022
0.6.1 Sep 19, 2020

#284 in Data structures

Download history 323/week @ 2024-09-21 291/week @ 2024-09-28 53/week @ 2024-10-05 128/week @ 2024-10-12 188/week @ 2024-10-19 82/week @ 2024-10-26 42/week @ 2024-11-02 27/week @ 2024-11-09 44/week @ 2024-11-16 40/week @ 2024-11-23 43/week @ 2024-11-30 105/week @ 2024-12-07 64/week @ 2024-12-14 23/week @ 2024-12-21 123/week @ 2024-12-28 56/week @ 2025-01-04

273 downloads per month
Used in 3 crates

MIT license

120KB
3K SLoC

AVL Tree Map and Set in Rust

Build and test

An ordered map and set implemented with an AVL tree (nearly balanced binary search tree) in Rust.

use avl::AvlTreeMap;

let mut map = AvlTreeMap::new();
map.insert(0, "zero");
map.insert(1, "one");
map.insert(2, "two");
assert_eq!(map.get(&1), Some(&"one"));
map.remove(&1);
assert!(map.get(&1).is_none());


use avl::AvlTreeSet;

let mut set = AvlTreeSet::new();
set.insert(0);
set.insert(1);
set.insert(2);
assert!(set.contains(&1));
set.remove(&1);
assert!(!set.contains(&1));

This is solely to get practice with the dark art of unsafe Rust. For all common purposes one of the standard library collections should be preferable.


lib.rs:

Dictionary data structures implemented with an AVL tree (nearly balanced binary search tree).

No runtime deps