- 1、本文档共21页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[2018年最新整理]二叉树的生成和遍历
《数据结构》课程设计报告———二叉树的生成和遍历 专 业 信息管理与信息系统 班 级 110514 小组成员 110514128 汤文莹110514129 王玉珏110514130 张蓓蕾110514131 张慕琦课程设计:二叉树的生成和遍历任务描述将二叉树以广义表形式存储在一个 TXT 文件上,通过读取 TXT 文件,建立二叉树; 求树的高度 实现二叉树的前序、中序和后序遍历; 将输出结果存储在文件内。二、问题分析1.设计思想以广义表格式输入一个二叉树,将其接收至一维数组中,利用栈结构建立二叉链表树;通过先、中、后访问根结点递归算法遍历二叉树;利用队列的入队、出队操作实现二叉树的层次遍历。例如:a(c(,d),f(g,))建立如下图所示二叉树。2.数据结构定义队列数组长度# define QueueMaxSize 20定义栈数组长度# define StackMaxSize 10定义二叉树数据类型typedef char ElemType;struct BTreeNode{ElemType data; struct BTreeNode * left; struct BTreeNode * right;}BTreeNode;3.主要模块设计初始化二叉树void InitBTree(struct BTreeNode** BT)根据a所定义的二叉树广义表字符串建立对应的存储结构void CreateBTree(struct BTreeNode ** BT,char * a) 前序遍历二叉树void Preorder(struct BTreeNode * BT){if(BT!=NULL) {printf(%c,BT-data); /*访问根结点*/ Preorder(BT-left); /*前序遍历左子树*/Preorder(BT-right); /*前序遍历右子树*/}}中序遍历二叉树void Inorder(struct BTreeNode * BT){if(BT!=NULL) {Inorder(BT-left); /*中序遍历左子树*/ printf(%c,BT-data); /*访问根结点*/ Inorder(BT-right); /*中序遍历右子树*/}}后序遍历二叉树void Postorder(struct BTreeNode * BT){if(BT!=NULL) { Postorder(BT-left); /*后序遍历左子树*/ Postorder(BT-right); /*后序遍历右子树*/ printf(%c,BT-data); /*访问根结点*/}}由指针指向的一颗二叉树的深度int BTreeDepth(struct BTreeNode * BT)按层遍历由BT指针所指向的二叉树void Levelorder(struct BTreeNode * BT4.详细设计1)二叉树的建立其中mark的值1、2、3、4分别指str[i]为字母、‘(’、‘,’、‘)’;tag为左、右孩子的标志;2.二叉树的层次遍历访问元素所指结点,若该元素所指结点的左右孩子结点非空,则该元素所指结点的左孩子指针和右孩子指针顺序入队。函数实现# includestdio.h# includestdlib.h# define QueueMaxSize 20 /*定义队列数组长度*/# define StackMaxSize 10 /*定义栈数组长度*/typedef char ElemType;struct BTreeNode{ElemType data; struct BTreeNode * left; struct BTreeNode * right;}BTreeNode;void InitBTree(struct BTreeNode** BT) /*初始化二叉树,即把树根指针置空*/{*BT=NULL;}void CreateBTree(struct BTreeNode ** BT,char * a) /*根据a所定义的二叉树广义表字符串建立对应的存储结构*/{struct BTreeNode * p; /*定义s数组作为存储根结点指针的栈使用*/struct BTreeNode * s[StackMaxSize]; /*定义top作为s栈的栈顶指针,初值为-1,表示空栈*/int top=-1; /*用k作为处理结点的左子树和右子树的标记,k=1处理左子树,k=2处理右子树*/i
您可能关注的文档
- [2018年最新整理]九下语文试卷.doc
- [2018年最新整理]九年级U10知识点.ppt
- [2018年最新整理]乘除运算中的误差分析.doc
- [2018年最新整理]九年级3-8知识点.ppt
- [2018年最新整理]九年级上册单项选择综合练习答案(Unit1).ppt
- [2018年最新整理]九年级上册复习提纲.doc
- [2018年最新整理]九年级上册数学北京课改版备课精品课件:《比例线段》.ppt
- [2018年最新整理]九年级上册数学认识一元二次方程教学知识点练习3.doc
- [2018年最新整理]九年级专项复习-单项选择之动词.doc
- [2018年最新整理]九年级上数学教案:比例线段.doc
- 2025年网络文学平台版权运营模式创新与版权保护体系构建.docx
- 数字藏品市场运营策略洞察:2025年市场风险与应对策略分析.docx
- 全球新能源汽车产业政策法规与市场前景白皮书.docx
- 工业互联网平台安全标准制定:安全防护与合规性监管策略.docx
- 剧本杀剧本创作审核标准2025年优化与行业自律.docx
- 2025年新能源电动巡逻车在城市安防中的应用对城市环境的影响分析.docx
- 全渠道零售案例精选:2025年行业创新实践报告.docx
- 2025年网约车司乘纠纷处理机制优化与行业可持续发展报告.docx
- 2025年宠物烘焙食品市场法规政策解读:合规经营与风险规避.docx
- 2025年宠物行业数据安全监管政策影响分析报告.docx
最近下载
- 汽车英语(第四版)习题答案.pdf VIP
- 苏科版《物质物理属性》复习总结课件.ppt VIP
- 一般过去时练习专项练习.docx VIP
- (市质检)福州市2025届高三第一次质量检测(一检) 语文试卷(含答案).docx
- 初中英语单词全集打印版.doc VIP
- 浪潮分布式存储InCloud Storage 用户手册.pdf VIP
- 量子传感技术的最新进展与应用.docx
- 专题20函数与相似综合问题-【压轴必刷】2022中考数学压轴大题之经典模型培优案(解析版).pdf VIP
- 医院医德医风考评制度及实施细则(最新版).docx
- (市质检)福州市2025届高三第一次质量检测(一检) 数学试卷(含答案).docx
文档评论(0)