# Left Leaning Red Black Tree (Insertion)

A left leaning Red Black Tree or (LLRB), is a variant of red black tree, which is a lot easier to implement than Red black tree itself and guarantees all the search, delete and insert operations in O(logn) time.

Which nodes are RED and Which are Black ?
Nodes which have double incoming edge are RED in color.
Nodes which have single incoming edge are BLACK in color.

Characteristics of LLRB
1. Root node is Always BLACK in color.
2. Every new Node inserted is always RED in color.
3. Every NULL child of a node is considered as BLACK in color.
Eg : only 40 is present in tree.

```
root
|
40 <-- as 40 is the root so it
/  \    is also Black in color.
NULL  NULL <-- Black in color.
```

4. There should not be a node which has RIGHT RED child and LEFT BLACK child(or NULL child as all NULLS are BLACK), if present Left rotate the node, and swap the colors of current node and its LEFT child so as to maintain consistency for rule 2 i.e., new node must be RED in color.

``` CASE 1.
root                        root
|                          ||
40      LeftRotate(40)     50
/  \\        --->          /  \
NULL  50                   40   NULL

root
|
ColorSwap(50, 40)      50
--->               //  \
40  NULL
```

5. There should not be a node which has LEFT RED child and LEFT RED grandchild, if present Right Rotate the node and swap the colors between node and it’s RIGHT child to follow rule 2.

```  CASE 2.
root                         root
|                            ||
40        RightRotate(40)    20
//  \         --->          //   \
20    50                    10    40
//                                   \
10                                     50

root
|
ColorSwap(20, 40)      20
--->                // \\
10   40
\
50
```

6. There should not be a node which has LEFT RED child and RIGHT RED child, if present Invert the colors of all nodes i. e., current_node, LEFT child, and RIGHT child.

```   CASE 3.
root                           root
|       !color(20, 10, 30)     ||
20            --->             20
//  \\                          /  \
10    30                        10  30

root
As the root is always black    |
--->                  20
/  \
10   30```

Why are we following the above mentioned rules? Because by following above characteristics/rules we are able to simulate all the red-black tree’s properties without caring about the complex implementation of it.
Example:

```Insert the following data into LEFT LEANING RED-BLACK
TREE and display the inorder traversal of tree.
Input : 10 20 30 40 50 25
Output : 10 20 30 40 50 25
root
|
40
//  \
20    50
/  \
10    30
//
25
```

Approach :
Insertions in the LLRB is exactly like inserting into a Binary search tree . The difference is that that After we insert the node into the tree we will retrace our steps back to root and try to enforce the above rules for LLRB.
While doing the above rotations and swapping of color it may happen that our root becomes RED in color so we also. We have to make sure that our root remains always BLACK in color.

`// C program to implement insert operation`
`// in Red Black Tree.`
`#include <stdio.h>`
`#include <stdlib.h>`
`#include <stdbool.h>`
`typedef` `struct` `node`
`{`
`    ``struct` `node *left, *right;`
`    ``int` `data;`
`    ``// red ==> true, black ==> false`
`    ``bool` `color; `
`} node;`
`// utility function to create a node.`
`node* createNode(``int` `data, ``bool` `color)`
`{`
`    ``node *myNode = (node *) ``malloc``(``sizeof``(node));`
`    ``myNode -> left = myNode -> right = NULL;`
`    ``myNode -> data = data;`
`    ``// New Node which is created is`
`    ``// always red in color.`
`    ``myNode -> color = ``true``;`
`    ``return` `myNode;`
`}`
`// utility funciton to rotate node anticlockwise.`
`node* rotateLeft(node* myNode)`
`{`
`    ``printf``(``"left rotation!!\n"``);`
`    ``node *child = myNode -> right;`
`    ``node *childLeft = child -> left;`
`    ``child -> left = myNode;`
`    ``myNode -> right = childLeft;`
`    ``return` `child;`
`}`
`// utility function to rotate node clockwise.`
`node* rotateRight(node* myNode)`
`{`
`    ``printf``(``"right rotation\n"``);`
`    ``node *child = myNode -> left;`
`    ``node *childRight =  child -> right;`
`    ``child -> right = myNode;`
`    ``myNode -> left = childRight;`
`    `
`    ``return` `child; `
`}`
`// utility funciton to check whether`
`// node is red in color or not.`
`int` `isRed(node *myNode)`
`{`
`    ``if` `(myNode == NULL) `
`       ``return` `0;`
`    ``return` `(myNode -> color == ``true``);`
`}`
`// utility function to swap color of two `
`// nodes.`
`void` `swapColors(node *node1, node *node2)`
`{`
`    ``bool` `temp = node1 -> color;`
`    ``node1 -> color = node2 -> color;`
`    ``node2 -> color = temp;`
`}`
`// insertion into Left Leaning Red Black Tree.`
`node* insert(node* myNode, ``int` `data)`
`{`
`    ``// Normal insertion code for any Binary`
`    ``// Search tree. `
`    ``if` `(myNode == NULL) `
`        ``return` `createNode(data, color);    `
`    ``if` `(data < myNode -> data) `
`        ``myNode -> left = insert(myNode -> left, data);`
`    ``else` `if` `(data > myNode -> data) `
`        ``myNode -> right = insert(myNode -> right, data);`
`    ``else`
`        ``return` `myNode;`
`    `
`    ``// case 1.`
`    ``// when right child is Red but left child is`
`    ``// Black or doesn't exist.`
`    ``if` `(isRed(myNode -> right) && !isRed(myNode -> left))`
`    ``{`
`        ``// left rotate the node to make it into`
`        ``// valid structure.`
`        ``myNode = rotateLeft(myNode);`
`        ``// swap the colors as the child node `
`        ``// should always be red`
`        ``swapColors(myNode, myNode -> left);`
`        `
`    ``}`
`    `
`    ``// case 2`
`    ``// when left child as well as left grand child in Red`
`    ``if` `(isRed(myNode -> left) && isRed(myNode -> left -> left))`
`    ``{   `
`        ``// right rotate the current node to make `
`        ``// it into a valid structure.`
`        ``myNode = rotateRight(myNode);`
`        ``swapColors(myNode, myNode -> right);`
`    ``}`
`    `
`    `
`    ``// case 3`
`    ``// when both left and right child are Red in color.`
`    ``if` `(isRed(myNode -> left) && isRed(myNode -> right))`
`    ``{`
`        ``// invert the color of node as well `
`        ``// it's left and right child.`
`        ``myNode -> color = !myNode -> color;`
`        ``// change the color to black.`
`        ``myNode -> left -> color = ``false``;`
`        ``myNode -> right -> color = ``false``; `
`    ``}`
`    ``return` `myNode;`
`}`
`// Inorder traversal`
`void` `inorder(node *node)`
`{`
`    ``if` `(node)`
`    ``{`
`        ``inorder(node -> left);`
`        ``printf``(``"%d "``, node -> data);`
`        ``inorder(node -> right); `
`    ``}`
`}`
`// Driver function`
`int` `main()`
`{`
`    ``node *root = NULL;`
`    ``/* LLRB tree made after all insertions are made.`
`            `
`    ``1. Nodes which have double INCOMING edge means`
`       ``that they are RED in color.`
`    ``2. Nodes which have single INCOMING edge means`
`       ``that they are BLACK in color.`
`    `
`        ``root`
`         ``|`
`         ``40`
`       ``//  \`
`      ``20    50`
`     ``/  \`
`   ``10    30`
`        ``//`
`       ``25    */`
`    ``root = insert(root, 10);`
`    ``// to make sure that root remains`
`    ``// black is color`
`    ``root -> color = ``false``;`
`    `
`    ``root = insert(root, 20);`
`    ``root -> color = ``false``;`
`    `
`    ``root = insert(root, 30);`
`    ``root -> color = ``false``;`
`   `
`    ``root = insert(root, 40);`
`    ``root -> color = ``false``;`
`    `
`    ``root = insert(root, 50);`
`    ``root -> color = ``false``; `
`    `
`    ``root = insert(root, 25);`
`    ``root -> color = ``false``; `
`    ``// display the tree through inorder traversal.`
`    ``inorder(root);`
`    `
`    ``return` `0;`
`}`

Output:

```10 20 25 30 40 50
```

Time Complexity : O(log n)

Disclaimer: This does not belong to TechCodeBit, its an article taken from the below
source and credits.
source and credits: http://www.geeksforgeeks.org
We have built the accelerating growth-oriented website for budding engineers and aspiring job holders of technology companies such as Google, Facebook, and Amazon
If you would like to study our free courses you can join us at