- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数计学院数据结构二叉树遍历课程设计-毕业论文(设计)
目录
一.问题描述 1
(1)题目: 1
(2)题目内容: 1
二.基本要求 1
三.工具/准备工作 1
四.分析与实现 2
(1)分析: 2
(2)核心算法代码: 2
①构建二叉树: 2
②二叉树的递归先序遍历: 3
③二叉树的递归中序遍历: 4
④二叉树的递归后续遍历: 4
⑤二叉树的节点查找: 5
⑥main函数部分: 6
⑦二叉树的非递归先序遍历: 9
⑧二叉树的非递归中序遍历: 10
⑨二叉树的非递归后序遍历: 11
五.测试与结论 13
六.课程设计总结 16
一.问题描述
(1)题目:二叉树的建立和后序遍历的演示。
(2)题目内容:利用单链表构建二叉树的链式存储,并能输入数据,然后分别用递归与非递归算法实现二叉树的中序遍历与后序遍历。
二.基本要求
(1)建立完整的二叉链表。
(2)程序可以输入数据。
(3)递归中序与后续遍历。
(4)非递归后续遍历
(1)添加了菜单选择功能
(2)添加了查找功能
(3)补全了三种遍历(递归与非递归)
三.工具/准备工作
(1)二叉树的链式存储结构
(2)二叉树的基本运算
复习参考 (3)二叉树的3种递归遍历
(4)二叉树的3种非递归遍历
(5)二叉树的节点查找
系统:Window 7
环境/工具:
软件:c-free
四.分析与实现
(1)分析:运用链来指示元素间的逻辑关系,表示一颗二叉树,具有链式存储的特点。另外,结合递归与非递归的思想算法,实现二叉树的三种遍历。
(2)核心算法代码:
①构建二叉树:
void create_tree(int x)
{
bt s,p;
int flag=0;
s=(treenode*)malloc(sizeof(treenode));
s-data=x;
s-left=NULL;
s-right=NULL;
if(root==NULL)
{
root=s;
}
else
{
p=root;
while(!flag)
{
if(xp-data)
{
if(p-left==NULL)
{
p-left=s;
flag=1;
}
else
p=p-left;
}
else
{
if(p-right==NULL)
{
p-right=s;
flag=1;
}
else
p=p-right;
}
}
}
}
②二叉树的递归先序遍历:
void xianxu(bt q)
{
if(q!=NULL)
{
printf(%4d,q-data);
xianxu(q-left);
xianxu(q-right);
}
}
③二叉树的递归中序遍历:
void zhongxu(bt q)
{
if(q!=NULL)
{
zhongxu(q-left);
printf(%4d,q-data);
zhongxu(q-right);
}
}
④二叉树的递归后续遍历:
void houxu(bt q)
{
if(q!=NULL)
{
houxu(q-left);
houxu(q-right);
printf(%4d,q-data);
}
}
⑤二叉树的节点查找:
bt search(bt a,int x)
{
bt p=NULL;
int i=1;
if(a)
{
if(a-data==x)
return a;
if(a-left)
{
p=search(a-left,x);
i=i++;
}
if(p)
{
return p;
}
if(a-right)
{
p=search(a-right,x);
i=i++;
}
if(p)
{
return p;
}
}
return NULL;
}
⑥main函数部分:
int main(void)
{
int i,k,x,a,v;
bt d;
root=NULL;
printf(\n\t\t*************************************);
printf(\n\t\t* 计科本113
您可能关注的文档
- 医院信息系统分析与设计课程设计指导书-.doc
- 十二五xx市(区)装备工业重大建设项目.doc
- 北京_京御地产孔雀城项目品牌管理实施方案_139PPT_2008年.ppt
- 十大食疗食物鸳鸯谱.doc
- 北师版最新六年级下册数学表格教案.doc
- 十款最适合妈妈家庭自制的辅食.doc
- 单片机GPS开题报告.doc
- 单片机毕业设计论文-基于51系列的单片机进行的实时日历和时钟显示设计.doc
- 单片机控制的三相全控桥触发系统设计-毕业设计-.doc
- 单片机秒表毕业论文-.doc
- 新PEP四年级英语上册全册教案.doc
- 新人教版2014二年级数学下册全册教案(已整理).docx
- 新人教版八年级上册精品教案.doc
- 新人教版最新2013年版五年级下册数学教案(整理后-135页)1.doc
- 新人教版英语七年级下全册教案.doc
- 新版PEP小学英语四年级上册Unit 5 dinner‘s ready.ppt
- 新目标人教版八年级英语下册Unit10__Ihave_had_this_bike_for_three_years_Section_A_(1a-2d)精品课件.ppt
- 新人教版八年级下Unit_7 what's the highest mountain in the world_sectionA2.ppt
- 新课程小学科学教学设计.doc
- 新目标英语八年级下unit7课件(全)would you mind turning down the music.ppt
文档评论(0)