Loading [MathJax]/jax/output/HTML-CSS/fonts/TeX/fontdata.js

2-3 tree on Rust

Revision en2, by kobae964, 2017-04-25 19:33:02

Hi everyone!

I recently implemented 2-3 tree, a balanced tree data structure. The key feature of this tree is, that all the leaves are at the same depth. The implementation is avaliable here: GitHub

Implementation Details

2-3 tree data structure is represented by an enum with three constructors: Tip, Two and Three. Tip is a leaf, with no elements inside. Two is a node with one element and two children, and Three is a node with two elements and three children.

The current implementation supports insert() operation only. It uses a helper function, named insert_sub(). tree.insert_sub(x) inserts an element x to a tree tree, and returns either:
(1) Ok(ret), meaning ret is the resulting tree, or
(2) Err((t1, t2, val)), meaning that the resulting tree has an overcrowded node, so it must be split into two trees t1, t2, with the middle element val moved up.
insert() invokes insert_sub(), and
(1) if the result was Ok(ret), returns ret, or
(2) if the result was Err((t1, t2, val)), returns Two(_, val, t1, t2).

Experiments

Two kinds of experiments were conducted. 1 million elements were inserted to a 2-3 tree, (1) in the ascending order and (2) in a random order.

(1) in the ascending order: http://ideone.com/62Seqz

(2) in a random order: http://ideone.com/6DHM21

Note that one has not only an asymptotic upper bound of depth, but also a strict upper bound , That is because all the leaves of the 2-3 tree are at the same depth. (A 2-3 tree of depth d has at least 2d - 1 nodes.)

Conclusion

We have the 2-3 tree data structure, implemented on Rust!

References

The code is available here: https://github.com/koba-e964/contest/blob/61af81645a9c1287e3302642696f4fb5e5db47fb/comm/TwoThreeTree.rs
http://ideone.com/62Seqz
http://ideone.com/6DHM21

The implementation was done with the aid of this slide: https://www.slideshare.net/sandpoonia/23-tree

Tags rust, b-trees, balanced, experiment

History

 
 
 
 
Revisions
 
 
  Rev. Lang. By When Δ Comment
en7 English kobae964 2017-04-25 20:22:57 43
en6 English kobae964 2017-04-25 20:20:56 15 Tiny change: 't unlike [treap](htt' -> 't unlike [experiments on treap](htt'
en5 English kobae964 2017-04-25 20:19:17 9 on Rust
en4 English kobae964 2017-04-25 20:18:12 341 Add ref to treap experiments (published)
en3 English kobae964 2017-04-25 20:07:53 420 Add graph
en2 English kobae964 2017-04-25 19:33:02 1140 Implementation details
en1 English kobae964 2017-04-25 19:04:02 1126 Skeleton (saved to drafts)