ImageVerifierCode 换一换
格式:DOC , 页数:26 ,大小:220KB ,
资源ID:4465469      下载积分:10 金币
验证码下载
登录下载
邮箱/手机:
验证码: 获取验证码
温馨提示:
支付成功后,系统会自动生成账号(用户名为邮箱或者手机号,密码是验证码),方便下次登录下载和查询订单;
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/4465469.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  
声明  |  会员权益     获赠5币     写作写作

1、填表:    下载求助     留言反馈    退款申请
2、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
3、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
4、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
5、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【丰****】。
6、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
7、本文档遇到问题,请及时私信或留言给本站上传会员【丰****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。

注意事项

本文(二叉树的应用数据结构课程设计样本.doc)为本站上传会员【丰****】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4008-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

二叉树的应用数据结构课程设计样本.doc

1、资料内容仅供您学习参考,如有不当之处,请联系改正或者删除。信息科学与技术学院数据结构课程设计报告题目名称: 二叉树的应用专业班级: 计算机科学与技术学生姓名: 陈 杰学生学号: 指导教师: 高 攀完成日期: -04目 录1、 课程设计的目的、 课程设计题目、 题目要求21.1课程设计的目的31.2课程设计的题目31.3题目要求32课程设计的实验报告内容:43课程设计的原程序代码:44运行结果165. 课程设计总结216参考书目221课程设计的目的1.1课程设计的目的:经过以前的学习以及查看相关资料,按着题目要求编写程序,进一步加强对编程的训练,使得自己掌握一些将书本知识转化为实际应用当中.在整

2、个程序中,主要应用的是链表,可是也运用了类.经过两种方法解决现有问题.1.2课程设计的题目: 二叉树的应用1.3题目要求:1. 建立二叉树的二叉链表存储算法2. 二叉树的先序遍历, 中序遍历和后序遍历输出3. 非递归的先序遍历, 中序遍历4. 二叉树的层次遍历5. 判断此二叉树是否是完全二叉树6. 二叉树的左右孩子的交换2课程设计的实验报告内容:7. 经过递归对二叉树进行遍历。二叉树的非递归遍历主要采用利用队进行遍历。此后的判断此二叉树是否是完全二叉树也才采用队, 而二叉树的左右孩子的交换则采用的是一个简单的递归。3课程设计的原程序代码:#includeusing namespace std;

3、#define MAXSIZE 100int sign=0;void menu();/typedef struct BiTNodechar data;BiTNode *left_child,*right_child;BiTNode,*BiTree;int CreateBiTree(BiTree &T)/创立二叉树 char ch; coutch; if(ch=#) T=NULL; else if(!(T=new BiTNode) coutdata=ch; CreateBiTree(T-left_child);/create leftchild CreateBiTree(T-right_chil

4、d); /create rightchild return 1;/判断此树是否是完全二叉树int LevelOrder1(BiTree &T)BiTree stackMAXSIZE;BiTreep;int front,rear;front=-1,rear=0;stackrear=T;while(rear!=front)front+;p=stackfront;if(p-left_child=NULL)&(p-right_child)sign=1;if(p-left_child)rear+;stackrear=p-left_child;if(p-right_child)rear+;stackrea

5、r=p-right_child;return 1;void Output(BiTree &T) /输出二叉树if(!T) cout空树!n;return ; /空树coutdataleft_child) Output(T-left_child); /输出左子树if(T-right_child)Output(T-right_child);/输出右子树int Depth(BiTree &T) /求树深int i,j;if(!T) return 0;i = Depth(T-left_child);j = Depth(T-right_child);return (ij?i:j) + 1;int Nod

6、e(BiTree &T)/求结点数if(!T) return 0;return 1+Node(T-left_child)+Node(T-right_child);int Leaf(BiTree &T) /求叶子结点if(!T) return 0;if(!T-left_child&!T-right_child) return 1;/仅有根结点return Leaf(T-left_child)+Leaf(T-right_child);/返回叶子结点的数目void PreOrder(BiTree &T) /先序遍历算法 DLRif(!T) return ; /递归调用的结束条件coutdatalef

7、t_child);/先序递归遍历T的左子树PreOrder(T-right_child);/先序递归遍历T的右子树void InOrder(BiTree &T)/中序遍历算法 LDRif(!T) return ;InOrder(T-left_child);coutdataright_child);void PostOrder(BiTree &T)/后序遍历算法 LRDif(!T) return ;PostOrder(T-left_child);PostOrder(T-right_child);coutdata ;/非递归先序遍历int NRPreOrder(BiTree &T)BiTree s

8、tack100,p;int top;if(T=NULL)return 1;top=-1;p=T;while(!(p=NULL&top=-1)while(p!=NULL)coutdata ;if(top100-1)top+;stacktop=p;else cout栈溢出left_child;if(top=-1)return 1;elsep=stacktop;top-;p=p-right_child; return 1;/非递归中序遍历int NRInOrder(BiTree &T)BiTree stack100,p;int top;if(T=NULL)return 1;top=-1;p=T;wh

9、ile(!(p=NULL&top=-1)while(p!=NULL)if(top100-1)top+;stacktop=p;else cout栈溢出left_child;if(top=-1)return 1;elsep=stacktop;coutdataright_child;return 1;/层次遍历void LevelOrder(BiTree &T)BiTree queue100;int front,rear;if(T=NULL)return;front=-1;rear=0;queuerear=T;while(front!=rear)front+;coutdataleft_child!=

10、NULL)rear+;queuerear=queuefront-left_child;if(queuefront-right_child!=NULL)rear+;queuerear=queuefront-right_child;/*左右子树交换*/*将结点的左右子树交换*/*BiTNode *swap(BiTNode &T) BiTNode *t,*t1,*t2; if(T=NULL) t=NULL; else t=(BiTNode *)malloc(sizeof(BiTNode); t-data=T-data; t1=swap(T-left_child); t2=swap(T-right_c

11、hild); t-left_child=t2; t-right_child=t1; return(t); void print(BiTNode &T) if(T!=NULL) printf(%c,T-data); if(T-left_child!=NULL|T-right_child!=NULL) printf(); print(b-left_child); if(b-right_child!=NULL)printf(, ); print(b-right_child); printf(); */int PreOrderTraverse(BiTree T) if(!T)return 0;BiTr

12、ee t;if (T-left_child|T-right_child) t=T-left_child;T-left_child=T-right_child;T-right_child=t;PreOrderTraverse(T-left_child);PreOrderTraverse(T-right_child);return 0;/菜单void menu() cout*endl; coutendl; cout*endl; coutendl; coutendl; coutendl; coutendl; coutendl; coutendl; coutendl; coutendl; couten

13、dl; coutendl; coutendl; coutendl; coutendl; cout*endl;/主函数void main() int br,a;BiTree T;br=CreateBiTree(T);while(1)menu();cout;cina;if(a=0|a=12)switch (a)case 0:cout建立后的二叉树为: n;Output(T);coutendl;system(pause);break;case 1:cout该树的树深为: Depth(T)endl;system(pause);break;case 2:cout该树的结点数: Node(T)endl;s

14、ystem(pause);break;case 3:cout该树的叶子结点为: Leaf(T)endl;system(pause);break;case 4:cout该树以先序遍历输出为: n;PreOrder(T);coutendl;system(pause);break;case 5:cout该树以中序遍历输出为:n;InOrder(T);coutendl;system(pause);break;case 6:cout该树以后序遍历输出为: n;PostOrder(T);coutendl;system(pause);break;case 7:cout该树的非递归先序遍历输出为:n; NRP

15、reOrder(T);coutendl;system(pause);break;case 8:cout该树的非递归中序遍历输出为:n; NRInOrder(T);coutendl;system(pause);break;case 9:cout该树的层次遍历: n;LevelOrder(T);coutendl;system(pause);break;case 10:LevelOrder1(T);if(sign=1)cout这不是一个完全二叉树。endl;else cout这是一个完全二叉树。endl;/break;system(pause);break;case 11:PreOrderTraverse(T); cout左右孩子已经替换成功endl;break;case 12:exit(-1);4运行结果:4. 1用二叉链表创立二叉树: 4.2主菜单 4.3求二叉树树深: 4.4二叉树结点数:4.5二叉树的中序遍历:4.6二叉树的层次遍历: 4.7左右孩子交换: 4.8左右孩子交换后的中序遍历: 4.9左右孩子交换后的层次遍历: 5. 课程设计总结: 此次课程设计使我对书本的知识有进一步了解。同时也是我知道自己的一些不足, 这次课程设计我是在书本与同学的帮助下完成的。它并不难, 可是我没有自己独自完成是我的错误。6参考书目: 1.数据结构课本2. 数据结构基本操作

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服