标准实验报告六.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
标准实验报告六

南昌航空实验报告课程名称:数据结构实验名称: 班级:姓名::指导教师评定:签名: 在二叉树上无论采用哪种遍历方法,都能够访问遍树中的所有结点。由于访问结点的顺序不同,前序遍历和中序遍历都很难达到设计的要求;但采用后序遍历二叉树是可行的,因为后序遍历是最后访问根结点,按这个顺序将访问过的结点存储到一个顺序栈中,然后再输出即可。因此我们可非递归地后序遍历二叉树bt,当后序遍历访问到结点*p时,此时栈stack中存放的所有结点均为给定结点*p的祖先,而由这些祖先便构成了一条从根结点到结点*p之间的路径。 为了加深对遍历二叉树的理解,在这里把实现二叉树的非递归遍历概念也加入到这个设计要求中。 本程序共分四个部分: (1)二叉树建立; (2)求指定结点路径; (3)二叉树的前、中、后序非递归遍历算法; (4)查找函数。 三、调试过程及实验结果 2最后程序运行结果如下所示: 二叉树的遍历与求结点路径 ========================= 1.建立二叉树存储结构 2.求二叉树的前序遍历 3.求二叉树的中序遍历 4.求二叉树的后序遍历 5.求指定结点的路径 0.退出系统 ========================= 请选择:0—5 1↙ (选择1后,系统会提示输入二叉树所对应的完全二叉树按层结点值序列。那么在提示后,输入字符序列ABCD@EF@G@@@@H@@@IJ#.#号表示输入字符的结束,按“回车”后,如果运行正常,系统会显示“二叉树的链表存储结构建立完成!”。而后又会显示主控菜单。 四、附录 源程序文件清单: (1)建立二叉树 cbt.c (2)求指定路径np.c (3)查找给定值结点的函数fxn.c (4)二叉树遍历文件blecs.c (5)主函数 建立二叉树 cbt.c BinTree CreateBinTree(BinTree bt) { BinTNode *Q[num]; BinTNode *s; int front,rear; char ch; ch=getchar(); bt=NULL; front=1; rear=0; while(ch1!=#) { s=NULL; if(ch!=@) { s=(BinTNode *)malloc(sizeof(BinTNode)); s-data=ch; s-lchild=s-rchild=NULL; } rear++; Q[rear]=s; if(rear==1) bt=s; else { if(s!=NULL Q[front]!=NULL) if(rear%2==0) Q[front]-lchild=s; else Q[front]-rchild=s; if(rear%2!=0) front++; } ch=getchar(); } return bt; } 求指定路径np.c void NodePath(BinTree bt,BinTNode *ch) { typede enum{FALSE,TRUE} boolean; BinTNode *stack[num]; int tag[num]; int i,top; boolean find; BinTNode *s; find=FALSE; top=0; s=bt; do { while(s!=NULL) { top++; stack[top]=s; tag[top]=0; s=s-lchild; , P class=MsoNormal style=TEXT-INDENT: 18pt; LINE-HEIGHT: 12pt; mso-char-indent-count: 2.0; mso-margin-top-alt: auto; mso-margin-bottom-alt: auto} if(top0) { s=stack[p]; if(tag[top]==1) { if(s==ch) { for(i=1;i=top;i++) printf(-%c,stack[i-data); find=TRUE; } else top--; s=stack[top]; } if(top0 !find) { if(tag[top]!=1) { s=s-rchild; tag[top]=1; } el

文档评论(0)

juhui05 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档