随笔-145  评论-173  文章-70  trackbacks-0

#include <iostream>
#include <iomanip>
using namespace std;

typedef struct BinaryTree
{
 int data;
 struct BinaryTree *l;
 struct BinaryTree *r;
}*BiTree,BiNode;
 
class BiSearchT
{
private:
 BiTree root;
public:
 BiSearchT() :root(NULL) {}
 int PreOrderTraverse(BiTree t,int (*Visit)(int e));
 int InOrderTraverse(BiTree t,int (*Visit)(int e));
 int InsertBST(BiTree *t,int e);
 void Delete(BiTree *p);
 bool DeleteBST(BiTree *t,int key);
 bool SearchBST(BiTree t,int key,BiTree f,BiTree *p);
};
//先序遍历二叉树T
int BiSearchT::PreOrderTraverse(BiTree t,int (*Visit)(int d))
{
 if(t)
 {
  if(Visit(t->data))
   if(PreOrderTraverse(t->l,Visit))
    if(PreOrderTraverse(t->r,Visit)) return 1;
    return 0;
    }else return 1;
}
//中序遍历二叉树T
int BiSearchT::InOrderTraverse(BiTree t,int (*Visit)(int d))
{
 if(t)
 {
  if(InOrderTraverse(t->l,Visit))
   if(Visit(t->data))
    if(InOrderTraverse(t->r,Visit)) return 1;
    return 0;
    }else return 1;
}
//二叉排序树上的查找递归算法
bool BiSearchT::SearchBST(BiTree t,int key,BiTree f,BiTree *p)
{
 if(!t)
  {*p=f;return false;}
  else if(key==t->data) {*p=t;return true;}
  else if(key<t->data) SearchBST(t->l,key,t,p);
  else SearchBST(t->r,key,t,p);
}
//插入算法
int BiSearchT::InsertBST(BiTree *t,int e)
{
 BiTree p;
 BiTree s;
 if(!SearchBST(*t,e,NULL,&p))
 {
  s=(BiTree)malloc(sizeof(BiNode));
  s->data=e;s->l=s->r=NULL;
  if(!p) *t=s;
  else if(e<p->data) p->l=s;
  else p->r=s;
  return true;
 }
 else return false;
}
//在二叉树中删除一个结点
void BiSearchT::Delete(BiTree *p)
{
 BiTree q,s;
 if(!(*p)->r)
 {
  q=(*p);
  (*p)=(*p)->l;
  free(q);
 }
 else if(!(*p)->l)
 {
  q=(*p);
  (*p)=(*p)->r;
  free(q);
 }
 else
 {
  q=s=(*p)->l;
  while(s->r) s=s->r;
  s->r=(*p)->r;
  free(*p);
  (*p)=q;
 }
}
//二叉排序树的删除
bool BiSearchT::DeleteBST(BiTree *t,int key)
{
 if(*t!=NULL)
 {
  if(key==(*t)->data) Delete(t);
  else
   if(key<(*t)->data) DeleteBST(&((*t)->l),key);
   else DeleteBST(&((*t)->r),key);
   return true;
 }
   else return false;
}
//输出二叉排序树的数据地域值
int printelem(int d)
{
 cout<<setw(4)<<d;
 return 1;
}

void main()
{
 BiTree sroot=NULL;
 BiTree Croot=NULL;
 int q,c,d,e,f,g,h,l,m,x;
 cout<<"..............................二叉排序树的基本操作.............................."<<endl;
 cout<<"请您输入十个正整数作为二叉排序树的十个结点:"<<endl;
 cin>>q>>c>>d>>e>>f>>g>>h>>l>>m>>x;
 int i,j,k,a[10]={q,c,d,e,f,g,h,l,m,x};
 int n=7,b[]={10,7,6,9,20,12,22};
 BiSearchT my;
 for(i=0;i<10;i++)
  my.InsertBST(&sroot,a[i]);
 cout<<"二叉排序树创建成功!"<<endl;
    cout<<"先序遍历二叉排序树:"<<endl;
 my.PreOrderTraverse(sroot,printelem);
 cout<<endl;
 cout<<"中序遍历二叉排序树:"<<endl;
 my.InOrderTraverse(sroot,printelem);
 cout<<endl;
    cout<<"请输入你要查找的元素:";
 cin>>i;
 if(i==q||i==c||i==d||i==e||i==f||i==g||i==h||i==l||i==m||i==x)
  cout<<"查找成功!"<<endl;
 else cout<<"查找失败!"<<endl;
 cout<<"请输入你要删除的元素(...输入的元素必须在二叉排序树中...):";
 cin>>j;
 my.DeleteBST(&sroot,j);
 cout<<"先序遍历二叉排序树:"<<endl;
 my.PreOrderTraverse(sroot,printelem);
 cout<<endl;
 cout<<"中序遍历二叉排序树:"<<endl;
    my.InOrderTraverse(sroot,printelem);
 cout<<endl;
    cout<<"在此基础上请输入你要插入的元素:";
 cin>>k;
 my.InsertBST(&sroot,k);
    cout<<"先序遍历二叉排序树:"<<endl;
 my.PreOrderTraverse(sroot,printelem);
 cout<<endl;
 cout<<"中序遍历二叉排序树:"<<endl;
    my.InOrderTraverse(sroot,printelem);
 cout<<endl;
}

posted on 2009-11-15 11:54 deercoder 阅读(1497) 评论(0)  编辑 收藏 引用 所属分类: 数据结构和算法分析

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理