- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构与算法实验
二叉树的操作与应用
学院:物理与电子学院
班级:电信1205
学号:1404120811
姓名:黄文超 二叉树的基本操作实现及其应用
一、实验目的
1.熟悉二叉树结点的结构和对二叉树的基本操作。
2.掌握对二叉树每一种操作的具体实现。
3.学会利用递归方法编写对二叉树这种递归数据结构进行处理的算法。
4.会用二叉树解决简单的实际问题。
二、实验内容
设计程序实现二叉树结点的类型定义和对二叉树的基本操作。该程序包括二叉树结构类型以及每一种操作的具体的函数定义和主函数。
1 按先序次序建立一个二叉树 ,
2按(A:先序 B:中序 C:后序 )遍历输出二叉树的所有结点
以上比做,以下选做
3求二叉树中所有结点数
4求二叉树的深度
三、实验步骤
㈠、数据结构与核心算法的设计描述
/* 定义DataType为char类型 */
typedef char DataType;
/* 二叉树的结点类型 */
typedef struct BitNode
{ DataType data;
struct BitNode *lchild,*rchild;
}*BitTree;
相关函数声明:
1、/* 初始化二叉树,即把树根指针置空 */
void BinTreeInit(BitTree *BT)
{
BT=(BitTree)malloc(sizeof(BitNode));
BT-data=NULL;
cout二叉树初始化成功!endl;
}
2、/* 按先序次序建立一个二叉树*/
int BinTreeCreat(BitTree BT)
{
char ch;
cinch;
if(ch==#) BT=NULL;
else
{
if(!(BT=(BitTree)malloc(sizeof(BitNode))))
exit(0);
BT-data=ch;
BinTreeCreat(BT-lchild);
BinTreeCreat(BT-rchild);
}
return 0;
}
3、/* 检查二叉树是否为空 */
void BinTreeEmpty(BitTree BT)
{
if(BT-data==NULL)
cout是空二叉树!endl;
else
cout不是空二叉树!endl;
}
4、/*按任一种遍历次序(包括按先序、中序、后序、按层次)输出二叉树中的所有结点 */
void BinTraverse(BitTree BT)//按先序序列建立二叉树
{
if(BT!=NULL)
{
coutBT-data;
BinTraverse(BT-lchild);
BinTraverse(BT-rchild);
}
}
5、/* 求二叉树的深度 */
int BinTreeDepth(BitTree BT)
{
int depthval;
if(BT)
{
int depthLeft=BinTreeDepth(BT-lchild);
int depthRight=BinTreeDepth(BT-rchild);
depthval=1+(depthLeftdepthRight?depthLeft:depthRight);
}
else depthval=0;
return depthval;
}
6、/* 求二叉树中所有结点数 */
int BinTreeCount(BitTree BT)
{
int node;
if(BT)
{
int lchild=BinTreeCount(BT-lchild);
int rchild=BinTreeCount(BT-rchild);
node=lchild+rchild+1;
}
else
node=0;
return node;
}
㈡、函数调用及主函数设计
㈢ 程序调试及运行结果分析
测试数据: 1、初始化二叉树; 2、按先序序列建立二叉树;3、判断二叉树是否为空;4、先序序列遍历二叉树;5、求二叉树的深度;6、求二叉树节点的个数。
数据测试如下截图:
㈣ 实验总结
通过这次二叉树的基本操作的代码设计与算法设计的学习,我学会了这章学的二叉树的基本操作的等基础值,同时也发现了自己的一些问题,比如基本知识不是太扎实,很多只是还不是太熟悉等问题,需要在今后的学习中更加努力,学好接下来的课程。
四、主要算法流程图及程序清单
1、主要算法流程图:
2、程序清单
#includeiost
文档评论(0)