Space-efficient Static Trees and Graphs
Guy Jacobson
(presented by Vaibhav Sagar (@vbhvsgr))
Data structures take up too much space!
A pointer to n possible
locations needs log2n bits
Data structures with n
items need O(nlog2n)
space for pointers!
The rent is too damn high!
Source: The Atlantic
Unlabeled binary trees only need 2n + o(n)
bits
One approach: balanced parentheses?
Better space usage, but inefficient to use
How do we get efficient space usage and efficient
operations?
Metrics for space and time
- Space: measured in bits
- Time: measured in bit-accesses
Rank
ranke(S, i):
The number of es at or before
index i
Select
selecte(S, i):
The index of the ith e
Time complexity
- O(log2n) at the
time of writing, O(1)
now!
Rank/Select beyond bitmaps
Implicit bitmap
data:image/s3,"s3://crabby-images/2f74b/2f74bf4b5e21310d2e0de373150dd7340f04a838" alt=""
Level-order binary marked
data:image/s3,"s3://crabby-images/4f918/4f91834989b4ea717377697e57d384f310cd2f48" alt=""
Level-order binary marked
- left-child(m) = 2 ⋅ rank(m)
- right-child(m) = 2 ⋅ rank(m) + 1
- parent(m) = select(⌊m/2⌋)
Level-order unary degree sequence
data:image/s3,"s3://crabby-images/cf4f5/cf4f5177e26b79b5010caaa9a7791dc316ca8da0" alt=""
Level-order unary degree sequence
- first-child = select0(rank(m)) + 1
- next-sibling = m + 1
- parent(m) = select(rank0(m))
Parentheses balancing
data:image/s3,"s3://crabby-images/daf51/daf519fdb52c1e571b7c0ca535f27d6efdf38aa9" alt=""
Bounded pagenumber graphs
data:image/s3,"s3://crabby-images/fa287/fa287d42c5849206df10adcc3ed4db07e1015c2c" alt=""
Bounded pagenumber graphs
- node-to-edge(m) = rank0(select(m) + 1)
- edge-to-node(e) = rank(select0(e))
Succinct data structures today
Semi-indexing
data:image/s3,"s3://crabby-images/dfe27/dfe27fec2a2af5be10a613499fc75e611f79e2ac" alt=""
Compact Data Structures
data:image/s3,"s3://crabby-images/78ae0/78ae0dacce2660f1b4a784c8ec361b9f083772db" alt=""