二叉排序树实现及果结截屏.doc

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
二叉排序树实现及果结截屏

一:需求分析 基本要求 以字符(\0)为输入结束标志,输入数列L,生成一棵二叉排 序树T; 对二叉排序树T作中序遍历,输出结果; 输入元素x,查找二叉排序树T,若存在含x的结点,则删除该结点,并作中序遍历(执行操作2);否则输出信息“没有该结点x”; 数据类型 要实现二叉排序数,必须先定义数据类型,本设计的输入数据为整型,输出的数据也为整型。 题目功能详细说明 要生成一棵二叉排序数T,元素类型为ElemType 在二叉排序树中查找其关键字等于给定值的结点是否存在 在二叉排序树中插入一个新结点,中序遍历所建二叉排序树,将得到一个按关键字有序的元素序列 二叉排序树的查找,可多次查找,并输出查找的结果 4.最后对输出结构进行分析 二.概要设计 1.二叉树是另一种树型结构,他的特点是每个结点至多只有两棵子树,并且,二叉树的子树有左右之分,其次序不能任意颠倒。 2.二叉树的存储结构 //-----------二叉树的顺序存储表示-------------- #define MAX-TREE-SIZE 100 //二叉树的最大结点数 Typedef TELem type sqbitree[MAX-TREE-SIZE];//0号单元存储根结点 sqBiTree bt 3.在不同的存储结构中,实现二叉树的操作方法也不同,如找结点X的双亲PARENT(T,E),在三叉链表中很容易实现,而在二叉链表中则需从根指针出发巡查. 4. if(!t) {*p=f;return (0);} /*查找不成功*/ else if(key==t-data) {*p=t;return (1);} /*查找成功*/ else if(keyt-data) searchBST(t-lchild,key,t,p); /*在左子树中继续查找*/ else searchBST(t-rchild,key,t,p); /*在右子树中继续查找*/ 5 calculateASL(node *t,int *s,int *j,int i) /*计算平均查找长度*/ { if(*t){ i++; /*i记录当前结点的在当前树中的深度*/ *s=*s+i; /*s记录已遍历过的点的深度之和*/ if(calculateASL((*t)-lchild,s,j,i))/*计算左子树的ASL*/ 三.详细程序 #includestdio.h # includestdlib.h typedef struct Tnode{ int data; /*输入的数据*/ struct Tnode *lchild,*rchild; /*结点的左右指针,分别指向结点的左右孩子*/ }*node,BSTnode; searchBST(node t,int key,node f,node *p) /*查找函数*/ { if(!t) {*p=f;return (0);} /*查找不成功*/ else if(key==t-data) {*p=t;return (1);} /*查找成功*/ else if(keyt-data) searchBST(t-lchild,key,t,p); /*在左子树中继续查找*/ else searchBST(t-rchild,key,t,p); /*在右子树中继续查找*/ } insertBST(node *t,int key) /*插入函数*/ { node p=NULL,s=NULL; if(!searchBST(*t,key,NULL,p)) /*查找不成功*/ { s=(node)malloc(sizeof(BSTnode)); s-data=key; s-lchild=s-rchild=NULL; if(!p) *t=s; /*被插结点*s为新的根结点*/ else if(keyp-data) p-lchild=s;/*被插结点*s为左孩子*/ else p-rchild=s; /*被插结点*s为右孩子*/ return (1); } else return (0);/*树中已有关键字相同的结点,不再插入*/ } inor

文档评论(0)

hagoulz + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档