ImageVerifierCode 换一换
格式:DOCX , 页数:13 ,大小:67.53KB ,
资源ID:10545276      下载积分:2 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

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

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据结构树和森林实验报告.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

数据结构树和森林实验报告.docx

1、数据结构树和森林实验报告树和森林应用实验实验报告实验目的(1)掌握树和森林的二叉链表表示方法。(2)掌握树和二叉树的结构及算法之间的对应关系。(3)掌握树的两种遍历算法及其应用。实验运行环境Visual C+实验任务为使实验程序简洁直观,下面的部分实验程序中的一些功能实现仍以调用库函数程序trees.h中的函数的形式给出,并假设该库函数中定义了树指针和结点类型分别为tree和tnode,以及部分常用运算,例如构建树(森林)、以某种方式显示树和森林等。各运算的名称较为直观,因而易于理解。读者可自行设计自己的库函数,也可到作者的网站下载。说明2:为便于数据的描述,和前面的实验一样,将测试数据结构列

2、出,并以一个文件名的形式给出标注,例如测试数据名为tree1.tre的树,其具体结构形式参见附录中的树列表中的标有tree1.tre的树。实验内容第一题:将一棵树(或森林)转换为二叉树。 实验测试数据基本要求:第一组数据: tree1.tre第二组数据: tree2.tre实验准备:用广义表来表示树的数据,保存到文件中,通过文件流来读入数据,并根据读入的数据来创建树第二题:求森林的高度。 实验测试数据基本要求:第一组数据: tree1.tre第二组数据: tree2.tre第一组数据: full41.cbt第二组数据: letter.cbt实验准备:遍历每一棵树,寻找高度的最大值。可以设立一个

3、私有成员来记录数的高度。第三题:按层次方式遍历森林。 实验测试数据基本要求:第一组数据: tree1.tre第二组数据: tree2.tre实验准备:先访问第一层结点,并将它放入队列中,并反复从队列中取结点,访问其孩子结点,直至访问到叶子结点。第四题:输出一个森林中每个结点的值及其对应的层次数。 实验测试数据基本要求:第一组数据: tree1.tre第二组数据: tree2.tre实验准备:使用递归函数来访问森林,同时输出层次数及结点值,使用形参来传递当前层次数第五题:输出一个森林的广义表形式,如下图中的森林的输出为:(a(b(c,d,e,f),g(h,i,j),k(l,m,n),o(p(q)

4、,r(s(t(u),v(w(x,y,z) 实验测试数据基本要求:第一组数据: tree1.tre第二组数据: tree2.tre实验准备:使用递归函数调用,若当前节点有左孩子,则先输出 (再访问下一节点,若当前节点的右指针不为空,则先输出,再访问下一结点。实验测试数据实验程序#include using namespace std;typedef char ElemType;#define MAX 200typedef struct CSNode ElemType data; struct CSNode *firstchild , *nejtsibling ; CSNode , *CSTree

5、;typedef struct BTNode ElemType data; struct BTNode *lchild , *rchild ; BTNode,*BTree;class FOREST public : FOREST(); CSTree returnT(); /输出森林的根结点 BTree returnBT(); /输出森林的根结点 CSTree creat(CSTree &T); /创建森林 BTree change(CSTree &T,BTree &BT1); /将森林转换成为二叉树 void first(CSTree &T,int i); /第一题:按照先序遍历的方式来输出树

6、林每个结点的值以及层次 void second(CSTree &T); /第五题:输出一个森林的广义表形式 void third(const CSTree &T); /第三题:按层次方式遍历森林。 void fourth(BTree &BT); /第四题:按照先序遍历的方式来输出二叉树每个结点的值 int higth(const CSTree &T); /第二题:求森林的高度 private : CSTree T; /森林的头结点 BTree BT; /二叉树的头结点 int high; /森林的高度 ;FOREST : FOREST() high = 0; T = NULL; BT = NU

7、LL; CSTree FOREST : returnT() return T; BTree FOREST : returnBT() return BT; CSTree FOREST : creat(CSTree &T) int a ,b; T = new CSNode; cinT-dataab; if(a = 1) T-firstchild = NULL; else creat(T-firstchild); if(b = 1) T-nejtsibling = NULL; else creat(T-nejtsibling); return T;BTree FOREST : change(CSTr

8、ee &T,BTree &BT) if(!T) BT = NULL; return NULL; BT = new BTNode; BT - data = T - data; if(!T-firstchild) BT-lchild = NULL; else change(T-firstchild,BT-lchild); if(!T-nejtsibling) BT-rchild = NULL; else change(T-nejtsibling,BT-rchild); return BT; void FOREST : first(CSTree &T,int i) if(!T) return ; c

9、outdata ifirstchild) first(T-firstchild,i+1); if(T-nejtsibling) first(T-nejtsibling,i); void FOREST : second(CSTree &T) if(!T) return ; coutdata; if(T-firstchild) coutfirstchild); if(T-nejtsibling) coutnejtsibling); else cout nejtsibling ; while(i!=j) CSTree q; q = Sj+; cout data firstchild; while(q

10、) Si+ = q; q = q - nejtsibling; void FOREST : fourth(BTree &BT) if(!BT) return ; coutdatalchild) fourth(BT-lchild); if(BT-rchild) fourth(BT-rchild); int FOREST : higth(const CSTree &T) int hs,hb; if(!T) return 0; hs = higth(T-firstchild) ; hb = higth(T-nejtsibling); high = (hs + 1) hb ? (hs + 1) : h

11、b; return high; int main() FOREST f_1,f_2,f_3,f_4,f_5; int chioce; coutendl; cout数据结构实验五-树和森林应用实验endl; coutendl; cout第1题: 将一棵树(或森林)转换为二叉树endl; cout第2题: 求森林的高度endl; cout第3题: 按层次方式遍历森林endl; cout第4题: 输出一个森林中每个结点的值及其对应的层次数endl; cout第5题: 输出一个森林的广义表形式endl; cout退出程序:0endl; coutendl; cout请选择一道题chioce; switc

12、h (chioce) case 1: cout请输入森林的元素endl; CSTree p1; BTree p; p1 = f_1.returnT();p = f_1.returnBT(); p1 = f_1.creat(p1); p = f_1.change(p1,p); cout按照二叉树先序遍历的结果是:endl; f_1.fourth(p); coutendl; break; case 2: cout请输入森林的元素endl; CSTree p2; p2 = f_2.returnT(); p2 = f_2.creat(p2); cout森林的高度是:; coutf_2.higth(p2

13、); coutendl; break; case 3: cout请输入森林的元素endl; CSTree p3; p3 = f_3.returnT(); p3 = f_3.creat(p3); cout按照层次遍历的结果是:endl; f_3.third(p3); coutendl; break; case 4: cout请输入森林的元素endl; CSTree p4; p4 = f_3.returnT(); p4 = f_3.creat(p4); cout按照森林先序遍历输出的结果是输出endl; cout一个森林中每个结点的值及其对应的层次数:endl; f_3.first(p4,1); coutendl; break; case 5: cout请输入森林的元素endl; CSTree p5; p5 = f_3.returnT(); p5 = f_3.creat(p5); cout输出一个森林的广义表形式:endl; f_3.second(p5); coutendl; break; case 0: coutEXITendl; break; default: cout输入错误,请重新输入endl; return 0 ;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1