Binary Search Tree (BST) is extensive approach to binary trees. In BST the left child of node will have a value lesser than it and its right child is going to have the value greater or equal to it.

#### BST Operations

- Insert â€“ adding new element in a tree or creating a tree.
- Deleteâ€”removal of any element from the tree.
- Search â€“ finding any element in tree.
- Traversal âˆ’ visiting nodes in any specific order.

##### 1.Insert Operation

First insertion of an element will create a tree with one node. Whenever second element need to be added to the tree, its proper location needs to be searched. Searching starts from root node, if data of the new node to be inserted is less than the root node value, then the new node will be inserted as left node of root. If data in new node is greater or equal to root than new node would be inserted as right node of the root. Subsequent addition to tree will follow the same procedure i.e. searching will start at root node, then either left or right subtree will be searched depending on the value of new node to be inserted and new node will be inserted depending on its proper position in tree.

##### Algorithm

1.If (root = NULL )then create new tree by adding root and return 2.If ( root!=NULL) then compare data of new node with node.data While( position for insertion is located) If (data > node.data) goto the right sub tree else goto the left subtree end while insert the data end If

##### Implementation

void insert_data ( int data) { struct tree_node^{*}temp_Node = (struct tree_node^{*}) malloc(sizeof(struct tree_node)); struct tree_node^{*}current; struct tree_node^{*}p; temp_Node->data = data; temp_Node->lchild = NULL; temp_Node->rchild = NULL; if(root = = NULL) { root = temp_Node; } else { current = root; p = NULL; while(1) { p = current; if(data < p->data) { current = current->lchild; if(current = = NULL) { p->lchild = temp_Node; return; } } else { current = current->rchild; if(current = = NULL) { p->rchild = temp_Node; return; } } } } }

##### 2.Search Operation

For searching we start searching an element from root node, if data or key to be searched is equal to root than element is found at root. If key is less than the root the element is searched in left sub tree else the key will be searched in right subtree. Process is repeated until key is found.

###### Algorithm

1.If (root.data = = search.data) Then return root 2.else while (data != found) If (data >node.data) goto the right subtree else goto the left subtree If ( data is found ) then return node end while return (data is not found) end if

###### Implementation

struct tree_node^{*}search(int data) { struct tree_node^{*}current = root; printf("Visiting elements: "); while(current->data != data) { if(current != NULL) printf("%d ",current->data); if((current-->data ) > data) { current = current--> lchild; } else { current = current-->rchild; } if(current = = NULL) { return (NULL); } return current; } }

##### 3. Delete Operation

On deleting a node from BST, three possibilities arise: -

Case 1: If the node for deletion is the leaf node then it is directly removed from tree.

Case 2: If the node for deletion is having only one child either left or right than we place the child at parent position (the node to be deleted) and original child position is deleted.

Case 3: If the node to be deleted is having two children, then find out the inorder successor of node to be deleted. Place the contents of inorder successor to node that needs to be deleted. Now deleted original inorder successor position as it is duplicate node now. This procedure can also be implemented by finding inorder predecessor.

###### Algorithm

1. search node to delete. 2. If ( node = = leaf node) i. If ( node = left child )then set left pointer of parent node= NULL && free the node. ii. If (node = = right child ) then set right pointer of parent node =NULL && free the node. 3. If ( node is having one child) i. If (node for deletion is left child) then set link between left pointer of its parent and child node which is to be deleted and delete node. ii.If ( node for deletion is a right child) then set link between right pointer of its parent and child node which is to be deleted and delete node. 4. If (node for deletion is having two children) i. find node with max value from left sub-tree of node to be deleted ii. replace value of node to be deleted by node which is found in above step 4(i) 5. Display the output

###### Implementation

tree_node Delete(tree_node root, int data) { if(root = = NULL) return root; else if(data < root-->data) root-->lchild = Delete(root-->lchild,data); else if (data > root-->data) root-->rchild = Delete(root-->rchild,data); else { if(root-->lchild = = NULL && root-->rchild == NULL) { delete root; root = NULL; } else if(root-->lchild = = NULL) { struct tree_node temp = root; root= root->rchild; delete temp; } else if(root-->rchild = = NULL) { struct tree_node temp = root; root = root-->lchild; delete temp; } else { tree_node^{*}temp = Find_Min(root-->rchild); root-->data = temp-->data; root-->rchild = Delete(root-->rchild,temp-->data); } } return root; }

## Sample Tutorial Problem

#### Finding Swaps

Raman is preparing very hard for his first job interview. He is also taking some coaching classes for interview questions. Every day he practice lot of the questions. One day he stuck with one question related to binary tree. In the questions a complete binary tree with M nodes and each node have an distinct integer x_{i} attached with it is given. You need to find the minimum number of swaps that you can make to convert the binary tree into binary search tree. In one swap, you can select any two nodes and swap their values.

You will be given an array representation of the binary tree. Root of the tree will be at x_{1}. Left child of root will be at x_{2} and right child of root will be at x_{3}. Left child of node at array position k will be at x_{2*k} and right child of node at array position k will be at x_{2*k+1}.

##### Input Format

Input 1: It will be an integer M (1 M 105), denoting the number of nodes.

Input 2: It will be an integer array where:

First line will tell the total number of rows M

Next each consecutive rows will specify xi (1 xi 105), denoting the value attached to ith node.

##### Output Format

It will be an integer, denoting the minimum number of swaps needed to convert binary tree into a binary search tree.

##### Sample TestCase 1

###### Input

3 1 2 3

###### Output

1