💾 Archived View for gem.sdf.org › s.kaplan › cheatsheets › data-structures-and-algorithms › red_blac… captured on 2024-03-21 at 15:43:20.

View Raw

More Information

⬅️ Previous capture (2023-09-08)

-=-=-=-=-=-=-

# Red-Black Tree Cheatsheet

## Overview

- Red-Black Tree is a self-balancing binary search tree.
- It provides worst-case O(log n) time complexity for search, insert, and delete operations.
- Each node is either red or black.
- The root node is always black.
- If a node is red, its children must be black.
- Every path from a given node to any of its descendant leaf nodes contains the same number of black nodes.

## Operations

### Insertion

def insert_node(root, key):

# Create a new node

new_node = Node(key)

# Insert the new node as a normal BST

root = bst_insert(root, new_node)

# Fix the Red-Black Tree properties

fix_violation(root, new_node)

# Return the root of the modified tree

return root


### Deletion

def delete_node(root, key):

# Find the node to delete

node = bst_delete(root, key)

# Fix the Red-Black Tree properties

fix_violation(root, node.parent)

# Return the root of the modified tree

return root


### Traversal

#### In-order Traversal

def in_order_traversal(node):

if node:

in_order_traversal(node.left)

print(node.key)

in_order_traversal(node.right)


## Time Complexity

- Insertion: O(log n)
- Deletion: O(log n)
- Traversal: O(n)

## Resources

- [Red-Black Tree Wikipedia](https://en.wikipedia.org/wiki/Red%E2%80%93black_tree)
- [GeeksforGeeks: Red-Black Tree](https://www.geeksforgeeks.org/red-black-tree-set-1-introduction-2/)
- [Red-Black Tree Visualization](https://www.cs.usfca.edu/~galles/visualization/RedBlack.html)