设为首页收藏本站

新微赢技术网

 找回密码
 注册
搜索
热搜: 回贴
查看: 455|回复: 5
打印 上一主题 下一主题

创建二叉排序树的问题(其它板块没人回)

[复制链接]
跳转到指定楼层
1#
发表于 2009-11-3 03:27:20 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创建二叉排序树的问题
#include<iostream>
using namespace std;
typedef struct Tree{
struct Tree *lchild,*rchild;
int data;
}TNode,*BiTree;
BiTree Search(BiTree T,int data,BiTree f,BiTree &p)
{// f初始值是NULL, 指向T的双亲
if(!T) p = f;
else if( T->data == data) p = T;
else if( T->data < data ) return Search(T->lchild,data,T,p);
else return Search(T->rchild,data,T,p);
}
void insert(BiTree &T,int data)
{
BiTree p,s;
if(!Search(T,data,NULL,p))
{
s = (BiTree)malloc(sizeof(TNode));
s->data = data; s->lchild = s->rchild = NULL;
if(!p) T = s;
else if(p->data > data) p->lchild = s;
else p->rchild = s;
}
}
void creatBiTree(BiTree &T)
{
int data;
do{
cin>>data;
insert(T,data);
}while(data!=0);
}
void printBiTree(BiTree &T)
{
if(T)
{
cout<<T->data<<endl;
printBiTree(T->lchild);
printBiTree(T->rchild);
}
}
int main()
{
BiTree t;
creatBiTree(t);
printBiTree(t);
system("pause");
2#
发表于 2009-11-3 03:27:21 | 只看该作者
你的目的是做什么啊?
回复 支持 反对

使用道具 举报

3#
发表于 2009-11-3 03:27:22 | 只看该作者
递归做的有什么意义?书上有全部代码。
回复 支持 反对

使用道具 举报

4#
发表于 2009-11-3 03:27:23 | 只看该作者
BiTree Search(BiTree T,int data,BiTree f,BiTree &p)
{// f初始值是NULL, 指向T的双亲
if(!T) p = f;
else if( T->data == data) p = T;
else if( T->data < data ) return Search(T->lchild,data,T,p);
else return Search(T->rchild,data,T,p);
}
这个应该要有返回值吧
回复 支持 反对

使用道具 举报

5#
发表于 2009-11-3 03:27:24 | 只看该作者
小弟初出茅庐,不知道能否帮我解决问题,万分感谢啊!
希望有编程的高手能解决我的疑难啊
回复 支持 反对

使用道具 举报

6#
发表于 2009-11-3 03:27:25 | 只看该作者
怎么找出来的呢 佩服
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

申请友链|小黑屋|最新主题|手机版|新微赢技术网 ( 苏ICP备08020429号 )  

GMT+8, 2024-11-18 13:41 , Processed in 0.109572 second(s), 10 queries , Gzip On, Memcache On.

Powered by xuexi

© 2001-2013 HaiAn.Com.Cn Inc. 寰耽

快速回复 返回顶部 返回列表