




已阅读5页,还剩3页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
数 据 结 构 实 验 报 告实验题目:二叉树相似问题姓名: 张耀班级: 计嵌151学号: 1513052017一、 实验目的设计一个算法,判断两棵树是否相似。、二、 数据结构设计(1) 设计二叉树的存储结构和建立算法(2) 设计二叉树相似的判断算法(3) 输入:两颗二叉树(4) 输出:判定结果,相似或不相似三、 算法设计与N-S图(1) 算法设计设计判断相似算法Like(BinTreeNode * A,BinTreeNode * B),该算法功能是若A与B相似,函数返回1,否则返回0。该算法从以下三个方面考虑。1. 若A=B=NULL,则A与B相似,即Like(A,B)=12. 若A与B中有一个为NULL,另一个不为NULL,则A与B不相似,即Like(A,B)=0;3. 采用递归方法,进一步判断A的左子树和B的左子树、A的右子树和B的右子树是否相似。(2) 程序流程图四、 程序清单#include stdafx.h#includeusing namespace std;static int count=1; struct BinTreeNode /二叉树结点类的定义char data; /结点的数据域BinTreeNode *lchild;/左孩子指针BinTreeNode *rchild;/右孩子指针;class BTree /二叉树类 public:BinTreeNode *root;BTree() root = NULL; /构造一棵空的二叉树void CreatBitree();/创建一棵二叉树void PretraBitree();/先序遍历二叉树;static void Create(BinTreeNode *p, int k) /创建二叉树BinTreeNode *q; char x;cinx;if(x!=#)q = new BinTreeNode;q-data=x; if(k=1) p-lchild=q;/k=1,把x存放左孩子结点if(k=2) p-rchild=q;/k=2,把x存放右孩子结点Create(q,1);Create(q, 2); else q = new BinTreeNode;q-data = x;q-lchild = NULL; q-rchild = NULL;if (k = 1)p-lchild = q; if (k = 2) p-rchild = q; void BTree:CreatBitree()BinTreeNode *p;char x; cin x;if (x = #)p = new BinTreeNode;p-data = x;p-lchild = NULL; p-rchild = NULL; else p = new BinTreeNode;p-data = x;root = p;Create(p, 1);Create(p, 2); static void pretraverse(BinTreeNode *p) /遍历二叉树if(p!=NULL) pretraverse(p-lchild); pretraverse(p-rchild); void BTree:PretraBitree() BinTreeNode *p;p = root;pretraverse(p); coutdata = #&b-data != #) | (a-data != #&b-data = #) count = 0; Like(a-lchild, b-lchild); Like(a-rchild, b-rchild); void work() BTree a; BTree b; cout 请按先序序列输入二叉树: endl; a.CreatBitree();/创建二叉树 A a.PretraBitree();/ 先序遍历二叉树 A cout请按先序序列输入二叉树:endl; b.CreatBitree();/创建二叉树 B b.PretraBitree();/ 先序遍历二叉树 B Like(a.root,b.root); /判断 AB 是否相似 cout判断结果:; if(count=1) coutA 与 B 相似endl; else coutA 与 B 不相似endl; int main() work(); return 0; 五、 运行与测试六、 实验分析及体会通过本次实验,进一步熟悉了二叉树的存储结构和相关操作。
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 22 科技改变世界说课稿-2025-2026学年小学科学六年级下册青岛版(六三制2024)
- Taking Action说课稿中职基础课-基础模块3-教科版(2021)-(英语)-52
- 慈善机构合同
- 第三节 合理发展交通运输说课稿初中地理商务星球版八年级上册-商务星球版2012
- 12.2 生物的进化 教学设计-京改版生物八年级上册
- 2025年农村新能源市场风力发电塔架技术创新报告
- 大学道路施工方案范本
- 第二课 给学习加点调味料教学设计初中心理健康南大版八年级全一册-南大版
- 机电系统应急预案
- 选唱 好朋友来了教学设计-2025-2026学年小学音乐三年级上册(2024)人音版(2024 主编:赵季平杜永寿)
- 2025届高考作文素材积累:高中五册课本素材及运用
- 学校思想政治教育管理制度
- 《设备管理台账》
- 人教版(2024新版)七年级上册 Unit1单元测试卷(含答案)
- 2023年中级注册安全工程师考试《安全生产法律法规》真题及答案
- 丽声北极星分级绘本五年级上教案:Stop!-Everyone-Stop
- 管理信息系统 课件 第6章 管理信息系统的战略规划
- 介绍钱三强的
- PEP小学英语3-6年级单词(带音标)
- pymodbus-实例说明文档
- 儿茶素没食子酸酯egcg茶多酚的分离与纯化
评论
0/150
提交评论