Here's an example of insertion into a red-black tree.
data:image/s3,"s3://crabby-images/b6e91/b6e919d40c1a4ca832ca1b8f93e05c33c5bf1611" alt="" | Here's the original tree ..
Note that in the following diagrams, the black sentinel nodes have been omitted to keep the diagrams simple. |
data:image/s3,"s3://crabby-images/72dc0/72dc0f166847d7ddadf237b6fbdf0d22e2d80e44" alt="" | The tree insert routine has just been called to insert node "4" into the tree. This is no longer a red-black tree - there are two successive red nodes on the path
11 - 2 - 7 - 5 - 4
Mark the new node, x, and it's uncle, y.
y is red, so we have case 1 ... |
data:image/s3,"s3://crabby-images/8d38c/8d38c9b06f8abdabda864c16e56f206ab8c2ed16" alt="" | Change the colours of nodes 5, 7 and 8. |
data:image/s3,"s3://crabby-images/926d3/926d30f1b9141dbb90b112ddcb31f01f9af7d5ac" alt="" | Move x up to its grandparent, 7. x's parent (2) is still red, so this isn't a red-black tree yet.
Mark the uncle, y.
In this case, the uncle is black, so we have case 2 ... |
data:image/s3,"s3://crabby-images/b7da0/b7da0f202d1cec3ce7d0c61a3ca14b407dd47f47" alt="" | Move x up and rotate left. |
data:image/s3,"s3://crabby-images/f11f0/f11f03d6ef8f25f983118a17ac8ea33c07009646" alt="" | Still not a red-black tree .. the uncle is black, but x's parent is to the left .. |
data:image/s3,"s3://crabby-images/9fb4a/9fb4a57fee63634c9a30735e071279e32e24f925" alt="" | Change the colours of 7 and 11 and rotate right .. |
data:image/s3,"s3://crabby-images/da3c9/da3c9772d1dc95ba2d4826e20a2774d17ff80205" alt="" | This is now a red-black tree, so we're finished! O(logn) time! |