- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
                        查看更多
                        
                    
                二叉树运算菜单实验报告
                    二叉树运算菜单实验报告一:问题描述:功能要求(1-3必做,其他选做),或Huffman编码 创建 遍历(先序、中序、后序、层序) 计算(结点数、叶子数、高度、宽度) 查找(找结点、找双亲、找孩子、找兄弟,找祖先) 判断(二叉排序树、平衡二叉树、完全二叉树) 处理(左右子树互换,销毁、删子树、插子树、复制) 二:算法描述:主函数用switch函数创建菜单,菜单下使用各个子函数完成各项功能。我使用的二叉树定义是链式定义,包括左孩子,右孩子,数据。创建用的是扩展二叉树的先序序列以保证唯一性。三:数据结构的描述:typedef struct BiTNode{char data;struct BiTNode *lchild,*rchild;}BiTNode,*BiTree;如上所示。四:算法时空分析:时间复杂度较为合理(因为用的是书上的算法。);空间复杂度一般,没编;几个函数就二百四十行了。五:实验收获:对二叉树的定义和使用有了更加清晰的认识,再一次的加强了编程能力,锻炼了耐心,发现了一个小知识,就是fflush(stdin)函数可以清空缓存,很有用。六:源程序:#includestdio.h#includemalloc.h#define BiTree_Size 20typedef struct BiTNode{//定义了二叉树结构体。char data;struct BiTNode *lchild,*rchild;}BiTNode,*BiTree;void Creat(BiTree t){//创建,#表示空。char e;fflush(stdin);scanf(%c,e);if(e==#)t=NULL;else{t=(BiTNode*)malloc(sizeof(BiTNode));t-data=e;Creat(t-lchild);Creat(t-rchild);}} void Pre(BiTree t){//前序遍历。if(!t)return;else{printf(%c ,t-data);Pre(t-lchild);Pre(t-rchild);}}void Mid(BiTree t){//中序遍历。if(!t)return;else{Mid(t-lchild);printf(%c ,t-data);Mid(t-rchild);}}void Post(BiTree t){//后续遍历。if(!t)return;else{Post(t-lchild);Post(t-rchild);printf(%c ,t-data);}}int Count(BiTree t,int i){//求节点数。if(!t)return i;else{i++;i=Count(t-lchild,i);i=Count(t-rchild,i);}return i;}int Yezi(BiTree t,int i){//求叶子树,利用先序遍历。if(!t)return i;else{if(t-lchild==NULLt-rchild==NULL)i++;i=Yezi(t-lchild,i);i=Yezi(t-rchild,i);}return i;}void Kuan(BiTree t,int a[],int i){//二叉树求宽度,a存放的下标表示层,内容表示宽度。if(!t)return;else{a[i]++;//printf(%d\n,a[i]);Kuan(t-lchild,a,i+1);Kuan(t-rchild,a,i+1);}return;}void Destroy(BiTree t){//销毁二叉树。if(!t)return;else{Destroy(t-lchild);Destroy(t-rchild);free(t);t=NULL;}}void Copy(BiTree t1,BiTree t2){//复制二叉树。if(!t1)return;else{ t2=(BiTNode*)malloc(sizeof(BiTNode));t2-data=t1-data;Copy(t1-lchild,t2-lchild);Copy(t1-rchild,t2-rchild);}}void main(){BiTree T[BiTree_Size]={NULL};int a[15]={0},menue,n1,n2,n3,n4,n5,n6,n7,n8,n9,n10,n11,max=0,i;while(1){printf(输入o表示退出\n); printf(输入1表示创建二叉树\n); printf(输入2表示先序二叉树\n); printf(输入3表示中序二叉树\n); printf(输入4表示后序二叉树\n); printf(输入5表示求节点数\n); printf(
                您可能关注的文档
最近下载
- 大班社会《危险游戏我不玩》.pptx VIP
- 2025年山西运城事业单位考试笔试试题(含答案).pdf
- 城市轨道交通运营设备维修与更新技术规范第5部分:通信.pdf VIP
- 医院感染暴发事件应急处理.pptx VIP
- 《食品营养学》 课件 第四章 各类食物的营养特点.pdf
- 基于BIM的建设工程文件归档管理系统.pdf VIP
- 护理学(专升本)模考试题(含参考答案).docx VIP
- 员工离职申请表(模版)(标准版).doc VIP
- 实验五___DPS统计分析操作.pptx VIP
- 《Unit 3 Lesson 3 Letters all around》(说课稿)-2024-2025学年冀教版(三起)(2024)英语三年级上册.docx VIP
 原创力文档
原创力文档 
                        

文档评论(0)