Red-Black Tree
Date: 2022-12-27Last modified: 2023-03-07
data:image/s3,"s3://crabby-images/856b4/856b43c28ecd3f523f48bcb4e8f6b80a46dacc25" alt=""
Red-black tree
-
Invented by Rudolf Bayer in 1972
-
A node is either red or black
-
The root and leaves (NIL) are black
-
If a node is red, then its children are black
-
All path from a node to its NIL descendants contains the same number of black nodes.
-
Nodes require one storage bit to keep track of color
-
The longest path (root do farthest NIL) is no more than twice the length of the shortest path (root to nearest NIL).
- Shortest path: all black nodes
- Longest path: alternating red and black
-
Operations are O(log n) time complexity
- Search
- Insert (require rotation)
- Remove (require rotation)
-
Space complexity are O(n)
data:image/s3,"s3://crabby-images/fe3e7/fe3e7d349c74fd5381e06b4dd4194a01aaa6cf71" alt="Left rotation"
data:image/s3,"s3://crabby-images/d188a/d188af661929335f2afe29cf6379e88b39b852e8" alt="Right rotation"