收藏 分享(赏)

7.2二叉树相似问题.doc

上传人:精品资料 文档编号:10411211 上传时间:2019-11-08 格式:DOC 页数:8 大小:82.21KB
下载 相关 举报
7.2二叉树相似问题.doc_第1页
第1页 / 共8页
7.2二叉树相似问题.doc_第2页
第2页 / 共8页
7.2二叉树相似问题.doc_第3页
第3页 / 共8页
7.2二叉树相似问题.doc_第4页
第4页 / 共8页
7.2二叉树相似问题.doc_第5页
第5页 / 共8页
点击查看更多>>
资源描述

1、数 据 结 构 实 验 报 告实验题目:二叉树相似问题姓名: 张耀班级: 计嵌 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

2、)=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

3、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存

4、放右孩子结点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 BinTreeNo

5、de;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 = #Like(a-lchild, b-lchild); Like(a-rchild, b-rchild); void work()BTree

6、a;BTree b;cout “请按先序序列输入二叉树:“ endl; a.CreatBitree();/创建二叉树 A a.PretraBitree();/ 先序遍历二叉树 Acout“请按先序序列输入二叉树:“endl;b.CreatBitree();/创建二叉树 Bb.PretraBitree();/ 先序遍历二叉树 B Like(a.root,b.root); /判断 AB 是否相似cout“判断结果:“; if(count=1) cout“A 与 B 相似“endl; else cout“A 与 B 不相似“endl; int main() work();return 0; 五、 运行与测试六、 实验分析及体会通过本次实验,进一步熟悉了二叉树的存储结构和相关操作。并且根据数据结构实验教程实验课本上关于对二叉树相似问题的分析和引导,完成了本次实验。本算法的核心是 Like(BinTreeNode *a, BinTreeNode *b),即是否判断相似的条件。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报