网站大量收购闲置独家精品文档,联系QQ:2885784924

叉树叶子结点数和高度.docVIP

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

江西理工大学软件学院 计算机类课程实验报告 课程名称: 数据结构 班 级: 姓 名: 学 号: 江西理工大学软件学院 实 验 五 实验名称 求二叉树叶子结点数和高度 实验日期 2012-12-11 实验成绩 实验目的、要求及内容 实验目的、要求: 加深理解二叉树的定义和特性; 掌握二叉树的存储结构与实现; 掌握二叉树的遍历操作及其应用 二、实验内容: 写出程序的运行结果,并上机验证 上机调试程序,根据键盘输入的扩展二叉树的前序遍历序列建立相应的二叉树,并计算该二叉树的叶子结点个数和高度。 上机调试,程序分析 编写程序 填写实验报告 实验环境 3423机房 操作系统:windows XP C环境: VC++ 6.0 算法描述及实验步骤 一、算法描述 存储结构:二叉链表 基本思想:利用二叉树的遍历操作,设计递归算法实现。 递归模式:一整棵二叉树树的叶子结点数 = 左子树的叶子结点数 + 右子树的叶子结点数 递归出口 二、实验步骤 写出程序的运行结果,并上机验证。 程序及运行结果如下: (1)输入创建一棵二叉树的结点数据:ab#c##D## 输出:前序遍历 abcD 该二叉树的叶子结点为:2 该二叉树的高度为:3 交换后的二叉树为:abDc (2) 输入创建一棵二叉树的结点数据:ABC#D###E## 输出:前序遍历 ABCDE 该二叉树的叶子结点为:2 该二叉树的高度为:4 交换后的二叉树为:AEBCD 上机调试程序,按规定格式输入数据 (1)输入创建一棵二叉树的结点数据:ab#c##D## 运行结果,正确。 (2) 输入创建一棵二叉树的结点数据:ABC#D###E## 运行结果,正确。 (3) 若输入格式错误,则无法得到结果。 上机调试,程序分析 编写程序 调试过程及实验结果 实验执行的结果: 输入创建一棵二叉树的结点数据:ab#c##D## (2) 输入创建一棵二叉树的结点数据:ABC#D###E## 总 结 课程实验不仅要求对课本知识有较深刻的了解, 同时要求我们有较强的思维和动手能力,需要 进一步了解编程思想和编程技巧。通过课程实验, 使我对课本知识掌握的更加深刻,增强了自己的 思维和动手能力。通过这次试验加深理解二叉树的定义 和特性;掌握二叉树的存储结构与实现;掌握二叉树的遍历操作及其应用 附 录 (源程序清单等) #includeiostream.h int count=0; struct BiNode { char data; BiNode *lchild,*rchild; }; class BiTree { public: BiTree(); ~BiTree(); void CountLeaf(BiNode *root); int BiTreeDepth(BiNode *root); BiNode *getroot(){return root;} void Swap(BiNode *root); // int IsSame(BiNode *root1,BiNode *root2); private: BiNode *root; BiNode *Creat(); void Release(BiNode *root); } ; BiTree::BiTree() { root=Creat(); } BiNode *BiTree::Creat() { BiNode *root; char ch; cinch; if(ch==#) return NULL; else { root=new BiNode; root-data=ch; root-lchild=Creat(); root-rchild=Creat(); } return root; } BiTree::~BiTree () { Release(root); } void BiTree::Release (BiNode *root) { if(root!=NULL) { Release(root-lchild ); Release(root-rchild ); delete root; } } void BiTree::CountLeaf

文档评论(0)

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

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

1亿VIP精品文档

相关文档