TL;DR
Zip trees are a new type of randomized binary search tree that use fewer random bits, improve efficiency through path merging techniques, and are theoretically and practically advantageous over previous structures.
Contribution
The paper introduces zip trees, a practical and efficient randomized binary search tree that reduces random bit usage and simplifies insertion and deletion operations.
Findings
Require only O(log log n) bits for largest rank
Simplify mapping between skip lists and binary search trees
Improve efficiency by unmerging and merging paths
Abstract
We introduce the zip tree, a form of randomized binary search tree that integrates previous ideas into one practical, performant, and pleasant-to-implement package. A zip tree is a binary search tree in which each node has a numeric rank and the tree is (max)-heap-ordered with respect to ranks, with rank ties broken in favor of smaller keys. Zip trees are essentially treaps (Seidel and Aragon 1996), except that ranks are drawn from a geometric distribution instead of a uniform distribution, and we allow rank ties. These changes enable us to use fewer random bits per node. We perform insertions and deletions by unmerging and merging paths ("unzipping" and "zipping") rather than by doing rotations, which avoids some pointer changes and improves efficiency. The methods of zipping and unzipping take inspiration from previous top-down approaches to insertion and deletion (Stephenson 1980;…
Peer Reviews
No public reviews on file for this paper yet. If you reviewed it on a platform where reviews are public (OpenReview, ICLR, NeurIPS, ICML), you can paste yours below so the community can read it here.
Code & Models
Videos
No videos yet. Explain this paper in a talk, walkthrough, or lecture? Add one.
