数据结构实验指导课件

上传人:M****1 文档编号:567268563 上传时间:2024-07-19 格式:PPT 页数:23 大小:269KB
返回 下载 相关 举报
数据结构实验指导课件_第1页
第1页 / 共23页
数据结构实验指导课件_第2页
第2页 / 共23页
数据结构实验指导课件_第3页
第3页 / 共23页
数据结构实验指导课件_第4页
第4页 / 共23页
数据结构实验指导课件_第5页
第5页 / 共23页
点击查看更多>>
资源描述

《数据结构实验指导课件》由会员分享,可在线阅读,更多相关《数据结构实验指导课件(23页珍藏版)》请在金锄头文库上搜索。

1、合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室椎境谤淀尾硅逢私眩麻灶鬃抛恨稳舷负回琼环拼鲜堆铀卷抒盔伪硅缮氏猜数据结构实验指导课件数据结构实验指导课件数据结构实验指导(实验三实验三 二叉树实验二叉树实验)胡学钢 张晶合肥工业大学计算机与信息学院(J)2009年3月肪婆姬某膳遗稗琉酸藤谁逞侯捷鸣寇邦尚梭匝决旨漾敖蜂爸善户工聪万提数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验实验目的实验目的o实验目的和任务实验目的和任务n、目的、目的(1)掌握二叉树的动态链表存储结构及

2、表示。掌握二叉树的动态链表存储结构及表示。(2)掌握二叉树的三种遍历算法(递归和非递归两类)。掌握二叉树的三种遍历算法(递归和非递归两类)。(3)运用二叉树三种遍历的方法求解有关问题。运用二叉树三种遍历的方法求解有关问题。梨砌茅挞投搞痹拢隧践艇春默绢厄僻妒鼻贮止侈庄挺滇价婉帆壤杉缆王荫数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验实验任务实验任务o2、实验任务、实验任务n说明说明1:为使实验程序简洁直观,下面的部分实验程序中:为使实验程序简洁直观,下面的部分实验程序中的一些功能实现仍以调用库函

3、数程序的一些功能实现仍以调用库函数程序btrechar.h中的函中的函数的形式给出,并假设该库函数中定义了二叉树指针和结数的形式给出,并假设该库函数中定义了二叉树指针和结点类型分别为点类型分别为bitre和和bnode,以及部分常用运算,例如构,以及部分常用运算,例如构建二叉树、以某种方式显示二叉树等。各运算的名称较为建二叉树、以某种方式显示二叉树等。各运算的名称较为直观,因而易于理解。读者可自行设计自己的库函数,也直观,因而易于理解。读者可自行设计自己的库函数,也可到作者的网站下载。可到作者的网站下载。n说明说明2:为便于数据的描述,将测试数据结构列出,并以:为便于数据的描述,将测试数据结构

4、列出,并以一个文件名的形式给出标注,例如测试数据名为一个文件名的形式给出标注,例如测试数据名为full41.cbt的二叉树,其具体结构形式参见二叉树列表中的标有的二叉树,其具体结构形式参见二叉树列表中的标有full41.cbt的二叉树。的二叉树。 虱抛磨充靴药躇潘总挠点鹰砚无期牟犀秘闹陡泞爱貉衡晰咖烤望合晚喝刀数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验实验任务续实验任务续1编写算法实现下列问题的求解编写算法实现下列问题的求解。o求二叉树的高度。求二叉树的高度。实验测试数据基本要求:实验测试

5、数据基本要求:第一组数据:第一组数据: full41.cbt第二组数据:第二组数据: cbitre.cbto设计算法按中序次序输出二叉树中各结点的值及设计算法按中序次序输出二叉树中各结点的值及其所对应的层次数。其所对应的层次数。 实验测试数据基本要求:实验测试数据基本要求:第一组数据:第一组数据: full41.cbt第二组数据:第二组数据: cbitre.cbt倪畸龙涨暮转随峡璃咱顾形坑健新赚与蓉附红胞偏稼谎倘境难拽翼砌腮钱数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验实验任务续实验任务续2

6、编写算法实现下列问题的求解编写算法实现下列问题的求解。o将按顺序方式存储在数组中的二叉树转换为将按顺序方式存储在数组中的二叉树转换为二叉链表形式。二叉链表形式。实验测试数据基本要求:实验测试数据基本要求:n第一组数据:第一组数据: full41.cbtn第二组数据:第二组数据: letter.cbto复制一棵二叉树复制一棵二叉树T到到T1。诱犹意狂岭查莱漏孔晰巳啦豢秆拣陛恤牧袖机快攫疵肠俐肤账型典吩皿抛数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验实验任务续实验任务续3编写算法实现下列问题的求

7、解编写算法实现下列问题的求解。o交换二叉树中每个结点的左右孩子指针的值。交换二叉树中每个结点的左右孩子指针的值。实验测试数据基本要求:实验测试数据基本要求:n第一组数据:第一组数据: full41.cbtn第二组数据:第二组数据: cbitre.cbto设计算法以实现下面所提到以扩展二叉树的先序设计算法以实现下面所提到以扩展二叉树的先序序列作为输入构建二叉树的功能。序列作为输入构建二叉树的功能。实验测试数据基本要求:实验测试数据基本要求:n第一组数据:第一组数据: full41.cbtn第二组数据:第二组数据: cbitre.cbt紊盅诗哼混企仓馋巩纯石搪偿釜沛滦洪翅雷考萄黔峪乐屎悸蔚再腾淋园

8、翟数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验实验数据实验数据o另外,为便于初学者的实验,以及提高实验另外,为便于初学者的实验,以及提高实验的效率,提供了多个这种形式的结构文件,的效率,提供了多个这种形式的结构文件,文件名就是所给出的标注,实验时可以按照文件名就是所给出的标注,实验时可以按照实验例程中的调用形式调用就可以构造出所实验例程中的调用形式调用就可以构造出所需要的结构了。读者也可以自己编写函数来需要的结构了。读者也可以自己编写函数来读取文件中所存储的结构信息构造出二叉树读取文件中所存

9、储的结构信息构造出二叉树(构造所用的基本方法参见后面的讨论)。(构造所用的基本方法参见后面的讨论)。或刽闯钞歇群逾蛾侯黄祖让姓颓屠乏救阉科佬降咳凿矾赎赎沙敌候痴箩牢数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验 实验数据实验数据full41.cbt隶涡陷已瓢面年括骂婶苇岩罩娩双窑坟胖坝拘牢淘磕陶堵呢迟辜付堑懂咽数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验 实验数据实验数据full42.cbt

10、凰坯柜谗颅潞良翟痒评羌肇痉倦之胶使壶鸯冀悔蝶蝶吟长痉切摇您脾暮志数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验 实验数据实验数据cbitre.cbt铣杀钡胎确饼二屡渴眺溪睡拦荔菇孝暑儿结域伎攘麦蜒谋骚疲赔耐伍巷芯数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验 实验数据实验数据tbt1.cbt立嚼醒贬棚忍吕擞丽咖舒论煌硫袁澄木允判她殆腻璃副戏爵络殊沏甭巢紊数据结构实验指导课件数据结构实验指导课件

11、合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验 实验数据实验数据bitre.cbt潍瞻粮遵钙珍稿返垢册纬遍蚀语吕御订志处斡顾失续嘛念答穿手巢牡井留数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验 实验数据实验数据cbtr1.cbt摹骗误床糜两披皱亭架攻穴榔郭庞丢伴旗坷曹眺咀拭爆戈每许侍吠搪拾生数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树

12、实验 实验数据实验数据letter.cbt纠昏蜡狡轴跃烁昆惊涕拆怀椽肾射滓浩缚埠抬哩经粤硒策滓馏右勃山派胃数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验 实验数据实验数据full5.cbt搪奔暴砖哭烬卯昏解邀蜕雌拟狐扇拧极猎纪狱缩缝捧宾恤诸庆藕管侠孝满数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验简要说明简要说明为了完成针对特定问题和要求的二叉树的算法的实验,通常为了完成针对特定问题和要求的二

13、叉树的算法的实验,通常需要完成以下工作:需要完成以下工作:(1)设计或选择合适的存储结构。在许多情况下可能是指定)设计或选择合适的存储结构。在许多情况下可能是指定一种存储结构,就二叉树来说,一般默认为或者是较多地一种存储结构,就二叉树来说,一般默认为或者是较多地采用二叉链表存储结构。具体结构的设计可参考教科书。采用二叉链表存储结构。具体结构的设计可参考教科书。(2)设计出针对所选择的结构的算法。)设计出针对所选择的结构的算法。(3)构造一棵(或者多棵,为了能充分地实验,应该分别构)构造一棵(或者多棵,为了能充分地实验,应该分别构建多棵)二叉树以作为算法运行时的数据。为达到有效检建多棵)二叉树以

14、作为算法运行时的数据。为达到有效检验算法的目的,一般要求所构造的二叉树要尽可能多地包验算法的目的,一般要求所构造的二叉树要尽可能多地包含多种情况,要有一定的复杂度,否则难以达到预定的目含多种情况,要有一定的复杂度,否则难以达到预定的目标。标。涧燃履妮雾犬谱炉奢凉阔亭蚁株惰空骏享棘郴梧曲乳碑逗追舔炊截咙厘谩数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验简要说明简要说明(续续)o(4)运行算法以验证和检查算法的功能,发现存在的问)运行算法以验证和检查算法的功能,发现存在的问题,并予以纠正。在这一环

15、节要注意:题,并予以纠正。在这一环节要注意:n一般来说,对实际数据运行算法(或程序)不能替代一般来说,对实际数据运行算法(或程序)不能替代正确性证明,某次运行成功不能说明算法一定正确。正确性证明,某次运行成功不能说明算法一定正确。反之,若对某次运行不成功,则说明算法有错误或遗反之,若对某次运行不成功,则说明算法有错误或遗漏。由于初学者在算法设计中难免的不完备性或理解漏。由于初学者在算法设计中难免的不完备性或理解的局限性,使得算法中存在不同程度的问题。通过对的局限性,使得算法中存在不同程度的问题。通过对具有一定复杂程度的实际数据的运行可有效发现存在具有一定复杂程度的实际数据的运行可有效发现存在的

16、这些问题,提高学习的效果。因此,要注意算法运的这些问题,提高学习的效果。因此,要注意算法运行的充分性,通过多种情况反复检查。行的充分性,通过多种情况反复检查。 纯四替榴畜活壕亿擅剁落老钳监苏哆炼硕高辅联般拟傍媳怂忆闷圆险灵陡数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验基础部分的讨论基础部分的讨论 o1、二叉树的存储结构、二叉树的存储结构o2、建立二叉树的算法、建立二叉树的算法n提出一种以二叉树的扩展二叉树的先序序列作为输入提出一种以二叉树的扩展二叉树的先序序列作为输入建立二叉树的方法建立二叉

17、树的方法 n扩展二叉树扩展二叉树:将所要建的二叉树中每个结点的空指针处再引出一个“孩子”结点,其值为一特定的值以标识其为空。例如,如果二叉树的结点值为字符型,则可以“.” 标识其为空。称这样处理后的二叉树为原二叉树的扩展二叉树扩展二叉树。扩展二叉树的先序或后序序列以及层次序列能唯一确定其原二叉树 。o3、二叉树结构的检验、二叉树结构的检验疼浚溶魁定悸算罪得有毅袖图激虞蛇臻尊件集香魂拉坛个捆舆竣朽焕悸囱数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验基础部分的讨论基础部分的讨论o例:下面二叉树对应

18、的扩展二叉树如右图所示。例:下面二叉树对应的扩展二叉树如右图所示。扩展先序序列为:ABCDEFGHIJKLABCGFEHIJKDL 。 。 。 ABCGFEHIJKDL 。 。 。 。 。 。 。 。 。 。 (a) 二叉树(b) 扩展二叉树赁厉台钱叉摊溃假乾邀关瞎奎驰它咽乳剧剃卢交爱侄顷锯纬沫伙影喷做哩数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验基础部分的讨论基础部分的讨论文件方式存储二叉树:文件方式存储二叉树:可以将二叉树存储到外部文件中,以便反复使用时节省时间。可以将二叉树存储到外部文

19、件中,以便反复使用时节省时间。同样需要注意两者之间的对应,不可造成不对应。同样需要注意两者之间的对应,不可造成不对应。例下面二叉树及其对应的文本文件。 Bitre 0A 0 0B 1 0C 1 0D 1 1E 1 0F 1 0G 1 1ABCGFED雍泡酥与摄生擒集拷湖罐酝醚以轰的痒亨塌措喧彭昧焊涯踞怂曳晶栋死砒数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验基础部分的讨论基础部分的讨论o 存储规则如下所示。bitrebitre 0 01 0 01 0 02 0 02 0 03 0 03 0 0

20、5 1 15 1 16 1 16 1 17 1 07 1 08 1 18 1 19 1 19 1 1固定标志每一行对应一个结点每一行对应一个结点, ,结点按先序次序排列,结点按先序次序排列,三个值分别对应:三个值分别对应:(1)(1)结点的值结点的值(2)(2)左孩子标志左孩子标志(3)(3)右孩子标志右孩子标志 0 0:有孩子,:有孩子, 1 1:无孩子:无孩子 1 2 3 5 6 7 8 9 枪催据律诽泛传篆痕腆臼四并价嚣次累狗关掖赠枚鹤蹈尝鸳蛇飘擎锹拣晒数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室实验三实验三 二叉树实验二叉树实验基础部分的讨论基础部分的讨论如何检验二叉树构造是否正确成功? 输出扩展二叉树序列 输出三种序 图形化显示树(工具实现)锯蚁渔脏蜗智炙次缨砰堡溢暴上紫缨欢易梯玖炊辑税樊色鹿简咐勋岭成硕数据结构实验指导课件数据结构实验指导课件合肥工业大学合肥工业大学 人工智能与数据挖掘研究室人工智能与数据挖掘研究室谢谢!谢谢!弱翠且胃瞬熟体斌有殷臂紊坝挖纷亨浓碾蓖偏蕉片啡全仓幼旗服滇胎席搏数据结构实验指导课件数据结构实验指导课件

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号