Binary Search Tree
Binary Search Tree
Binary Search Tree
#include <stdio.h>
#include <stdlib.h>
struct Node
{
struct Node *lchild;
int data;
struct Node *rchild;
}*root=NULL;
if(root==NULL)
{
p=(struct Node *)malloc(sizeof(struct Node));
p->data=key;
p->lchild=p->rchild=NULL;
root=p;
return;
}
while(t!=NULL)
{
r=t;
if(key<t->data)
t=t->lchild;
else if(key>t->data)
t=t->rchild;
else
return;
}
p=(struct Node *)malloc(sizeof(struct Node));
p->data=key;
p->lchild=p->rchild=NULL;
if(key<r->data) r->lchild=p;
else r->rchild=p;
}
while(t!=NULL)
{
if(key==t->data)
return t;
else if(key<t->data)
t=t->lchild;
else
t=t->rchild;
}
return NULL;
}
if(p==NULL)
{
t=(struct Node *)malloc(sizeof(struct Node));
t->data=key;
t->lchild=t->rchild=NULL;
return t;
}
if(key < p->data)
p->lchild=RInsert(p->lchild,key);
else if(key > p->data)
p->rchild=RInsert(p->rchild,key);
return p;
return p;
}
return p;
}
struct Node *Delete(struct Node *p,int key)
{
struct Node *q;
if(p==NULL)
return NULL;
if(p->lchild==NULL && p->rchild==NULL)
{
if(p==root)
root=NULL;
free(p);
return NULL;
}
return p;
}
int main()
{
struct Node *temp;
root=RInsert(root,50);
RInsert(root,10);
RInsert(root,40);
RInsert(root,20);
RInsert(root,30);
Delete(root,30);
Inorder(root);
printf("\n");
temp=Search(20);
if(temp!=NULL)
printf("element %d is found\n",temp->data);
else
printf("element is not found\n");
return 0;
}