- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《二叉树基本操作演示程序的设计与实现
二叉树基本操作演示程序的设计与实现 2012级电器信息类 注意:文档以word格式提供,文件名起名规则:学号+姓名+实验报告名称 首先请输入二叉树结点序列: 请按菜单提示操作: ----------------------------欢迎使用二叉树基本操作程序------------------------------- 菜单选择 1. 树状输出二叉树 2. 先序遍历二叉树 3. 中序遍历二叉树 4. 后序遍历二叉树 5. 输出叶子结点 6. 输出叶子结点个数 7. 输出二叉树的深度 8. 括号形式输出二叉树 9. 退出 -------------------------------------------------------------------------------------------------- 图1 二叉树基本操作程序主菜单 2、存储结构设计 本程序采用二叉链式存储类型(BiTNode)存储二叉树的结点信息。二叉树的链表中的结点至少包含3个域:数据域(data)、左孩子指针域(lchild)、右孩子指针域(rchild)。 3、系统功能设计 本程序除了完成二叉树的创建功能外还设置了9个子功能菜单。由于这9个子功能都是建立在二叉树的构造上的,所以二叉树的创建由主函数main()实现。9个子功能的设计描述如下: ⑴树状输出二叉树。树状输出二叉树由函数TranslevelPrint()实现。当用户选择此功能时,系统即以树状的形式输出用户所创建的二叉树。 ⑵先序遍历二叉树。由函数Preorder()实现。该功能按照先序遍历访问二叉树的方法输出先序序列。 ⑶中序遍历二叉树。由函数Inorder()实现。该功能按照中序遍历访问二叉树的方法输出中序序列。 ⑷后序遍历二叉树。由函数Postorder()实现。该功能按照后序遍历访问二叉树的方法输出后序序列。 ⑸输出叶子结点。该功能采用先序遍历二叉树的方法依次输出叶子结点。由函数Preorderleaf()实现。 ⑹输出叶子结点个数。该功能计算并输出二叉树中叶子结点的个数,由LeafCount()实现。采用递归算法计算二叉树中叶子结点的个数,算法思想是:当二叉树为空树时,叶子结点总数为0;当二叉树只有1个结点时,叶子结点总数为1;否则,叶子结点个数等于左右子树叶子结点数之和。 ⑺输出二叉树的深度。该功能输出二叉树的深度,由函数PostorderDepth()实现,采用后序遍历的递归算法求二叉树的深度。 ⑻括号形式输出二叉树。以括号形式输出二叉树由函数,由函数output()实现。当用户选择此功能时,系统即以括号形式输出二叉树。 ⑼退出。由exit(0)函数实现。 三、模块设计 1、模块设计 本程序包含三个模块,主程序模块、建立二叉树模块和工作区选择模块。其调用关系如图2所示。 图2 模块调用示意图 2、系统子程序用功能设计 本系统共设置12个子程序,各子程序的函数名及功能说明如下: ⑴void CreateBiTree(BiTree T) //先序建立二叉树 ⑵void TranslevelPrint(BiTree T) //树形打印二叉树 ⑶void Visit(char ch) //输出结点 ⑷void Preorder(BiTree T) //先序遍历二叉树 ⑸void Inorder(BiTree T) //中序遍历二叉树 ⑹void Postorder(BiTree T) //后序遍历二叉树 ⑺void PreorderLeaf(BiTree T) //输出叶子结点 ⑻int LeafCount(BiTree T) //输出叶子结点的个数 ⑼int PostorderDepth(BiTree T) //输出二叉树的深度 ⑽void output(BiTree T) //以括号形式输出二叉树 ⑾void mainwork() //主工作函数,操作区用户界面 ⑿void main() //主函数。创建二叉树,调用工作区模块函数 3、函数主要调用关系图 本系统12个子程序之间的主要调用关系如图3所示。图中数字是各函数的编号。 图3系统函数调用
您可能关注的文档
最近下载
- JSCC B系列变频器产品手册.pdf VIP
- 部编版语文四年级上册第16课《麻雀》 配套练习(含解析).pdf VIP
- 认识医生和护士幼儿园助教幼儿园医学科普.pptx VIP
- 标准图集-19S910:自动喷水灭火系统设计.pdf VIP
- 成人经鼻高流量湿化氧疗临床规范应用专家共识.pptx VIP
- 数字化赋能下的高校教学质量监控与改进机制研究教学研究课题报告.docx
- 《成人无创通气设备相关面部压力性损伤风险评估与预防指南》解读PPT课件.pptx VIP
- 慈善组织保值增值投资活动管理暂行办法.docx VIP
- C836056【强化】2024年重庆大学100100基础医学《660基础医学综合(西医)之生理学》考.pdf VIP
- 提高手术患者术前准备完善率医院护理品管圈QCC成果汇报.pptx VIP
有哪些信誉好的足球投注网站
文档评论(0)