- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
二叉树的建立;二叉树的建立;二叉树的建立;对二叉树最重要的是根,它起定位的作用,因此,首先建立的是根结点。也就是说,如果从键盘输入数据来建立二叉树,第一个数据就是这棵树的根的数据,之后再输入的数据,每一个都要与根中的数据作比较,以便确定该数据所在结点的插入位置。假定我们这里依然用图1的中序遍历的方式。即如果待插入结点的数据比根结点的数据小,则将其插至左子树,否则插入右子树。
定义一个递归函数
void insert(struct TREE **proot, struct TREE *p)
其中,指针p指向含有待插入数据的结点。
proot为树的根指针的地址。
insert函数棵理解为将p结点插入到*proot所指向的树中。;insert(proot, p)可用下列与或结点图来描述;注意在上图中proot是被调用函数的形参。从前面对它的定义看,proot是指针的指针,实际上是指向二叉树根结点的指针的指针,或者说是指向二叉树根结点的指针的地址。如下图。因此,在主程序调用insert函数时,;#include stdio.h // 预编译命令
#include malloc.h // 内存空间分配
#define null 0 // 定义空指针常量
#define LEN sizeof(struct TREE) // 定义常量,表示结构长度
struct TREE // 结构声明
{
int data; // 整型数
struct TREE *L,*R; // TREE结构指针
};;// 被调用函数insert,将结点插入二叉树
void insert (struct TREE **proot, struct TREE* p)
{ // 函数体开始
if (*proot==null) // 如果根结点为空
{
*proot = p; // 将结点p插入根结点
return; // 返回
}
else // 根结点不为空
{
// 如果p结点数据小于等于根结点数据
if (p-data = (*proot)-data)
insert( ((*proot)-L), p); // 插入左子树
else // 如果p结点数据大于等于根结点数据
insert( ((*proot)-R), p); // 插入右子树
}
} // 函数体结束;// 被调用函数,形参为TREE结构指针,输出二叉树内容
void print(struct TREE *root)
{ // 函数体开始
if (root == null) // 根或子树根结点为空
return; // 返回
print(root-L); // 输出左子树内容
printf(%d,root-data);// 输出根结点内容
print(root-R); // 输出右??树内容
} // 被调用函数结束
void main() // 主函数开始
{ // 函数体开始
struct TREE *root, *p; // TREE型结构指针
int temp; // 临时变量,用于用户输入数据
root = null; // 初始化二叉树根结点为空
p = null; // 初始化待插入结点的指针为空
printf(请输入待插入结点的数据\n); // 提示信息
printf(如果输入-1表示插入过程结束\n);// 提示信息
scanf(%d,temp); // 输入待插入结点数据; while(temp != -1) // 当型循环,-1为结束标志
{ // 循环体开始
// 为待插入结点分配内存单元
p = (struct TREE *) malloc(LEN);
p-data = temp; // 将temp赋值给p结点的数据域
p-L = p-R = null; // 将p结点的左右指针域置为空
insert( root, p ); // 将p结点插入到根为root的树中, // root表示二叉树根结点的地址
printf(请输入待插入结点的数据\n); // 提示信息
printf(如果输入-1表示插入过程结束\n);// 提示信息
scanf(%d,temp); // 输入待插入结点数据
} // 循环体结束
if (root==null) // 如果根结点为空
printf(这是一棵空树。\n);// 输出空树信息
else // 根结点不为空
print(root); //
文档评论(0)