Thursday, 29 November 2012

Binary Search tree (BST) operations


/*Binary Search tree with insertion, deletion.....processes
compiler- Turbo c++     author- Mangilal Sharma
--------------------------------------------------------*/
# include <iostream.h>
# include <stdlib.h>
# include <conio.h>

struct bs_node
{
 int element;
 bs_node *left;
 bs_node *right;
 int height;
};

typedef struct bs_node *bs_nodeptr;

class bst
{
 public:
  bst();
      void insert(int,bs_nodeptr &);
      void del(int,bs_nodeptr &);
       int deletemin(bs_nodeptr &);
      void find(int,bs_nodeptr &);
bs_nodeptr findmin(bs_nodeptr);
bs_nodeptr findmax(bs_nodeptr);
      void copy(bs_nodeptr &,bs_nodeptr &);
      void makeempty(bs_nodeptr &);
bs_nodeptr bs_nodecopy(bs_nodeptr &);
      void preorder(bs_nodeptr);
      void inorder(bs_nodeptr);
      void postorder(bs_nodeptr);
       int bsheight(bs_nodeptr);
bs_nodeptr srl(bs_nodeptr &);
bs_nodeptr drl(bs_nodeptr &);
bs_nodeptr srr(bs_nodeptr &);
bs_nodeptr drr(bs_nodeptr &);
       int nobs_nodes(bs_nodeptr);
       int maxx(int value1,int value2)
       {
return ((value1 > value2) ? value1 : value2);
       }
};

void bst::insert(int x,bs_nodeptr &p)
{
 if (p == NULL)
 {
  p = new bs_node;
  p->element = x;
  p->left=NULL;
  p->right = NULL;
  p->height=0;
  if (p==NULL)
  cout<<"Out of Space";
 }
 else
 {
  if (x<p->element)
  {
   insert(x,p->left);
   if ((bsheight(p->left) - bsheight(p->right))==2)
   {
    if (x < p->left->element)
    p=srl(p);
    else
    p = drl(p);
   }
  }
  else if (x>p->element)
  {
   insert(x,p->right);
   if ((bsheight(p->right) - bsheight(p->left))==2)
   {
    if (x > p->right->element)
    p=srr(p);
    else
    p = drr(p);
   }
  }
  else
  cout<<"Element Exists";
 }
 int m,n,d;
 m=bsheight(p->left);
 n=bsheight(p->right);
 d=maxx(m,n);
 p->height = d + 1;
}

bs_nodeptr bst::findmin(bs_nodeptr p)
{
 if (p==NULL)
 {
  cout<<"Empty Tree";
  return p;
 }
 else
 {
  while(p->left !=NULL)
  p=p->left;
  return p;
 }
}

bs_nodeptr bst::findmax(bs_nodeptr p)
{
 if (p==NULL)
 {
  cout<<"Empty Tree";
  return p;
 }
 else
 {
  while(p->right !=NULL)
  p=p->right;
  return p;
 }
}

void bst::find(int x,bs_nodeptr &p)
{
 if (p==NULL)
 cout<<"Element not found";
 else
 if (x < p->element)
 find(x,p->left);
 else
 if (x>p->element)
 find(x,p->right);
 else
 cout<<"Element found !";
}

void bst::copy(bs_nodeptr &p,bs_nodeptr &p1)
{
 makeempty(p1);
 p1 = bs_nodecopy(p);
}

void bst::makeempty(bs_nodeptr &p)
{
 bs_nodeptr d;
 if (p != NULL)
 {
  makeempty(p->left);
  makeempty(p->right);
  d=p;
  free(d);
  p=NULL;
 }
}

bs_nodeptr bst::bs_nodecopy(bs_nodeptr &p)
{
 bs_nodeptr temp;
 if (p==NULL) return p;
 else
 {
  temp = new bs_node;
  temp->element = p->element;
  temp->left = bs_nodecopy(p->left);
  temp->right = bs_nodecopy(p->right);
  return temp;
 }
}

void bst::del(int x,bs_nodeptr &p)
{
 bs_nodeptr d;
 if (p==NULL)
 cout<<"Element not found";
 else if ( x < p->element)
 del(x,p->left);
 else if (x > p->element)
 del(x,p->right);
 else if ((p->left == NULL) && (p->right == NULL))
 {
  d=p;
  free(d);
  p=NULL;
  cout<<" Element deleted !";
 }
 else if (p->left == NULL)
 {
  d=p;
  free(d);
  p=p->right;
  cout<<" Element deleted !";
 }
 else if (p->right == NULL)
 {
  d=p;
  p=p->left;
  free(d);
  cout<<" Element deleted !";
 }
 else
 p->element = deletemin(p->right);
}

int bst::deletemin(bs_nodeptr &p)
{
 int c;
 cout<<"inside deltemin";
 if (p->left == NULL)
 {
  c=p->element;
  p=p->right;
  return c;
 }
 else
 {
  c=deletemin(p->left);
  return c;
 }
}

void bst::preorder(bs_nodeptr p)
{
 if (p!=NULL)
 {
  cout<<p->element<<"-->";
  preorder(p->left);
  preorder(p->right);
 }
}

void bst::inorder(bs_nodeptr p)
{
 if (p!=NULL)
 {
  inorder(p->left);
  cout<<p->element<<"-->";
  inorder(p->right);
 }
}

void bst::postorder(bs_nodeptr p)
{
 if (p!=NULL)
 {
  postorder(p->left);
  postorder(p->right);
  cout<<p->element<<"-->";
 }
}

int bst::bsheight(bs_nodeptr p)
{
 int t;
 if (p == NULL) return -1;
 else
 {
  t = p->height;
  return t;
 }
}

bs_nodeptr bst:: srl(bs_nodeptr &p1)
{
 bs_nodeptr p2;
 p2 = p1->left;
 p1->left = p2->right;
 p2->right = p1;
 p1->height = maxx(bsheight(p1->left),bsheight(p1->right)) + 1;
 p2->height = maxx(bsheight(p2->left),p1->height) + 1;
 return p2;
}

bs_nodeptr bst:: srr(bs_nodeptr &p1)
{
 bs_nodeptr p2;
 p2 = p1->right;
 p1->right = p2->left;
 p2->left = p1;
 p1->height = maxx(bsheight(p1->left),bsheight(p1->right)) + 1;
 p2->height = maxx(p1->height,bsheight(p2->right)) + 1;
 return p2;
}

bs_nodeptr bst:: drl(bs_nodeptr &p1)
{
 p1->left=srr(p1->left);
 return srl(p1);
}

bs_nodeptr bst::drr(bs_nodeptr &p1)
{
 p1->right = srl(p1->right);
 return srr(p1);
}

int bst::nobs_nodes(bs_nodeptr p)
{
 int count=0;
 if (p!=NULL)
 {
  nobs_nodes(p->left);
  nobs_nodes(p->right);
  count++;
 }
 return count;
}

bst::bst()
{
 clrscr();
 bs_nodeptr root,root1,minn,maxx;
 int a,choice,findele,delele,leftele,rightele,flag;
 root =NULL;
 root1=NULL;
 while(1)
 {
  cout<<"\n\tOperations on Binary Search tree..\n";
  cout<<"\t\t1.  Insertion\n";
  cout<<"\t\t2.  FindMin\n";
  cout<<"\t\t3.  FindMax\n";
  cout<<"\t\t4.  Find\n";
  cout<<"\t\t5.  Copy\n";
  cout<<"\t\t6.  Delete\n";
  cout<<"\t\t7.  Preorder\n";
  cout<<"\t\t8.  Inorder\n";
  cout<<"\t\t9.  Postorder\n";
  cout<<"\t\t10. Height\n";
  cout<<"\t\t11. To main page\n";
  cout<<"\t\t12. Exit\n";
  cout<<"\n\t\t      Enter Your Choice= ";
  cin>>choice;
  switch(choice)
  {
   case 1:
 cout<<"Enter new bs_nodes value:";
 cin>>a;
 insert(a,root);
 break;
   case 2:
 if (root !=NULL)
 {
  minn=findmin(root);
  cout<<"Min element : "<<minn->element;
 }
 break;
   case 3:
 if (root !=NULL)
 {
  maxx=findmax(root);
  cout<<"Max element : "<<maxx->element;
 }
 break;
   case 4:
 cout<<"Enter Search bs_node :";
 cin>>findele;
 if (root != NULL)
 find(findele,root);
 break;
   case 5:
 copy(root,root1);
 inorder(root1);
 break;
   case 6:
 cout<<"Enter bs_node that u want to delete:";
 cin>>delele;
 del(delele,root);
 inorder(root);
 break;
   case 7:
 cout<<" Preorder travers... :";
 preorder(root);
 break;
   case 8:
 cout<<" Inorder travers.... :";
 inorder(root);
 break;
   case 9:
 cout<<" Postorder travers... :";
 postorder(root);
 break;
   case 10:
 cout<<" Height and Depth is ";
 cout<<bsheight(root);
 cout<<"\nNo. of bs_nodes is "<<nobs_nodes(root);
 break;
   case 11:
  return;
   case 12:
  exit(1);
   default:
  cout<<"\n\t\tWrong Choice, Enter Again\n";
  }
 }
}
/*=========================14Nov.,2010=============================*/

No comments:

Post a Comment

You are welcome, your comment helps me to make this blog more better.