数据结构实验五 二叉树及其应用

数据结构实验五 二叉树及其应用

ID:47518061

大小:102.00 KB

页数:5页

时间:2020-01-12

数据结构实验五 二叉树及其应用_第1页
数据结构实验五 二叉树及其应用_第2页
数据结构实验五 二叉树及其应用_第3页
数据结构实验五 二叉树及其应用_第4页
数据结构实验五 二叉树及其应用_第5页
资源描述:

《数据结构实验五 二叉树及其应用》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、计算机系数据结构实验报告(5)实验目的:树是数据结构中应用极为广泛的非线性结构,本单元的实验达到熟悉二叉树的存储结构的特性,以及如何应用树结构解决具体问题。问题描述:首先,掌握二叉树的各种存储结构和熟悉对二叉树的基本操作。其次,以二叉树表示算术表达式的基础上,设计一个十进制的四则运算的计算器。-+/a*b-efCd如算术表达式:a+b*(c-d)-e/f实验要求:文法是一个四元1、如果利用完全二叉树的性质和二叉链表结构建立一棵二叉树,分别计算a)统计叶子结点的个数。b)求二叉树的深度。2、十进制的四则运算的计算器可以接收用户来自键盘的输入。3、由输入的表达式字符串动态

2、生成算术表达式所对应的二叉树。4、自动完成求值运算和输出结果。算法分析:用二叉树表示表达式,可以按先序次序输入表达式,为了实现四则运算,输入后按书面格式输出原式,再进行运算,最后输出结果。另外,构造两个函数Leaf()和Height()来完成叶子节点和深度的计算。这是流程。先序输入构造二叉树采用最常用的递归调用,Leaf()和Height()的原理很简单,构造起来不难,主要的问题是字符输入与节点数据会有小数的矛盾和二叉树表示的表达式的运算的规则。其中注意到,四则运算的数据可能是小数,所以为了与之匹配,节点数据采用浮点型,先把字符输入的数据进行相应的处理,存入一个数组中

3、,再在构造二叉树的时候,从数组中获得数据。运算时则通过判断叶子节点与非叶子节点,进行浮点型与字符型的转换,再按四则运算法则求解,同样需要利用递归调用。实验内容和过程:源程序:#include#includeusingnamespacestd;staticfloatnode[100];inti=0;//-----二叉树的二叉链表存储表示------5-typedeffloatTElemType;typedefstructBiTNode{TElemTypedata;structBiTNode*lchild,*rchild;}BiTN

4、ode,*BiTree;intdataprocess(){charch;intj=1;floatm;intflag=0;ch=getchar();while(ch!='$'){if(!((ch>='0'&&ch<='9')

5、

6、ch=='.')){node[j]=(int)ch;flag=0;j++;ch=getchar();continue;}if(ch>='0'&&ch<='9'&&flag==1){--j;node[j]=node[j]*10+((int)ch-48);}if(ch=='.'){m=1;--j;ch=getchar();while(ch>='0'&

7、&ch<='9'){m=0.1*m;node[j]=node[j]+m*((int)ch-48);ch=getchar();}++j;continue;}if(ch>='0'&&ch<='9'&&flag==0){node[j]=(int)ch-48;flag=1;}++j;ch=getchar();}}intPreCreateBiTree(BiTree&T){++i;if(node[i]==35){T=NULL;return0;}if(!(T=(BiTNode*)malloc(sizeof(BiTNode))))exit(-1);T->data=node[i];Pr

8、eCreateBiTree(T->lchild);PreCreateBiTree(T->rchild);-5-return1;}intoutput(BiTreeT){charch;if(!T->lchild&&!T->rchild)cout<data;else{ch=(char)T->data;cout<data==42

9、

10、T->data==47)&&(T->lchild->data==43

11、

12、T->lchild->data==45)){printf("(");rere

13、ad(T->lchild);printf(")");}else{reread(T->lchild);}output(T);if((T->data==42

14、

15、T->data==47)&&(T->rchild->data==43

16、

17、T->rchild->data==45)){printf("(");reread(T->rchild);printf(")");}else{reread(T->rchild);}return1;}intLeaf(BiTreeT){intp,q;if(!T)return0;if(!T->lchild&&!T->rchild)re

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。