数据结构应用题练习.doc

上传人:博****1 文档编号:561326180 上传时间:2023-02-26 格式:DOC 页数:13 大小:1.16MB
返回 下载 相关 举报
数据结构应用题练习.doc_第1页
第1页 / 共13页
数据结构应用题练习.doc_第2页
第2页 / 共13页
数据结构应用题练习.doc_第3页
第3页 / 共13页
数据结构应用题练习.doc_第4页
第4页 / 共13页
数据结构应用题练习.doc_第5页
第5页 / 共13页
点击查看更多>>
资源描述

《数据结构应用题练习.doc》由会员分享,可在线阅读,更多相关《数据结构应用题练习.doc(13页珍藏版)》请在金锄头文库上搜索。

1、1、假设一棵二叉树的层序序列是ABCDEFGHIJ和中序序列是DBGEHJACIF,请画出该树。21、有一个完全二叉树按层次顺序存放在一维数组中,如下所示: 请指出结点P的父结点,左子女,右子女。3、给出下列二叉树的先序序列。4、已知二叉树的先序遍历序列为ABCDEFGH,中序遍历序列为CBEDFAGH,画出二叉树。答案:二叉树形态 (2)设一棵二叉树的先序序列: A B D F C E G H ,中序序列: B F D A G E H C画出这棵二叉树。画出这棵二叉树的后序线索树。将这棵二叉树转换成对应的树(或森林)。 ABMFD(3)CEMHG (1) (2)1、已知一棵二叉树的前序序列为

2、:A,B,D,G,J,E,H,C,F,I,K,L中序序列:D,J,G,B,E,H, A,C,K,I,L,F。i. 写出该二叉树的后序序列;ii. 画出该二叉树;iii. 求该二叉树的高度(假定空树的高度为1)和度为2、度为1、及度为0的结点个数。该二叉树的后序序列为:J,G,D,H,E,B,K,L,I,F,C,A。该二叉树的形式如图所示:ABJKIFCGEDLH该二叉树高度为:5。度为2的结点的个数为:3。度为1的结点的个数为:5。度为0的结点个数为:4。5、试用权集合12,4,5,6,1,2构造哈夫曼树,并计算哈夫曼树的带权路径长度。答案: WPL=12*1+(4+5+6)*3+(1+2)*

3、4=12+45+12=696、已知权值集合为5,7,2,3,6,9,要求给出哈夫曼树,并计算带权路径长度WPL。答案:(1)树形态: (2)带权路径长度:WPL=(6+7+9)*2+5*3+(2+3)*4=44+15+20=79(3) 假设用于通信的电文仅由8个字母组成,字母在电文中出现的频率分别为0.07,0.19,0.02,0.06,0.32,0.03,0.21,0.10。 试为这8个字母设计赫夫曼编码。 试设计另一种由二进制表示的等长编码方案。 对于上述实例,比较两种方案的优缺点。解:方案1;哈夫曼编码先将概率放大100倍,以方便构造哈夫曼树。 w=7,19,2,6,32,3,21,10

4、,按哈夫曼规则:【(2,3),6, (7,10)】, 19, 21, 32 0 1 0 1 0 119 21 32 0 10 1 0 17 10 6 0 12 3 (100)(40) (60)19 21 32 (28)(17) (11) 7 10 6 (5) 2 3方案比较:字母编号对应编码出现频率111000.072000.193111100.02411100.065100.326111110.037010.21811010.10字母编号对应编码出现频率10000.0720010.1930100.0240110.0651000.3261010.0371100.2181110.10方案1的WP

5、L2(0.19+0.32+0.21)+4(0.07+0.06+0.10)+5(0.02+0.03)=1.44+0.92+0.25=2.61方案2的WPL3(0.19+0.32+0.21+0.07+0.06+0.10+0.02+0.03)=3结论:哈夫曼编码优于等长二进制编码2应用题(1)已知如图6.27所示的有向图,请给出: 每个顶点的入度和出度; 邻接矩阵; 邻接表; 逆邻接表。 图6.27 有向图 2 AOE网G如下所示,求关键路径。(要求标明每个顶点的最早发生时间和最迟发生时间,并画出关键路径)答案:(1)最早发生时间和最迟发生时间: (2)关键路径: (2)已知如图6.28所示的无向网

6、,请给出: 邻接矩阵; 邻接表; 最小生成树图6.28 无向网 ab4c3ba4c5d5e9ca3b5d5h5db5c5e7f6g5h4eb9d7f3fd6e3g2gd5f2h6hc5d4g6(3)已知图的邻接矩阵如6.29所示。试分别画出自顶点1出发进行遍历所得的深度优先生成树和广度优先生成树。图6.29 邻接矩阵(2)根据prim算法,求图G从顶点1出发的最小生成树,要求表示出其每一步生成过程。(用图或者表的方式均可)。答案:(1)广度优先遍历序列:1; 2, 3, 4; 5; 6 (2)最小生成树(prim算法)V1V5V4V6V761V2V8V561. 对下面的有向图,从顶点V1开始进

7、行遍历,试画出遍历得到的DFS生成森林和BFS生成森林。遍历得到的DFS生成森林和BFS生成森林如下图:V1V5V4V6V761V2V8V56DFS生成森林V1V5V4V6V761V2V8V56BFS生成森林(5)设哈希表的地址范围为017,哈希函数为:H(key)=key%16。用线性探测法处理冲突,输入关键字序列:(10,24,32,17,31,30,46,47,40,63,49),构造哈希表,试回答下列问题: 画出哈希表的示意图; 若查找关键字63,需要依次与哪些关键字进行比较? 若查找关键字60,需要依次与哪些关键字比较? 假定每个关键字的查找概率相等,求查找成功时的平均查找长度。画表

8、如下:012345678910111213141516173217634924401030314647查找63,首先要与H(63)=63%16=15号单元内容比较,即63 vs 31 ,no;然后顺移,与46,47,32,17,63相比,一共比较了6次!查找60,首先要与H(60)=60%16=12号单元内容比较,但因为12号单元为空(应当有空标记),所以应当只比较这一次即可。对于黑色数据元素,各比较1次;共6次;对红色元素则各不相同,要统计移位的位数。“63”需要6次,“49”需要3次,“40”需要2次,“46”需要3次,“47”需要3次,所以ASL=1/11(6233+6)23/11设散列

9、表的长度为m=13,散列函数为H(k)=k MOD m,给定的关键码序列为19,14,23,1,68,20,84,27,55,11,13,7,试写出用线性探查法解决冲突时所构造的散列表。答案:表形态:(2)在一棵空的二叉排序树中依次插入关键字序列为12,7,17,11,16,2,13,9,21,4,请画出所得到的二叉排序树。 127 17 2 11 16 21 4 9 13验算方法: 用中序遍历应得到排序结果: 2,4,7,9,11,12,13,16,17,21(3)已知如下所示长度为12的表:(Jan, Feb, Mar, Apr, May, June, July, Aug, Sep, Oc

10、t, Nov, Dec) 试按表中元素的顺序依次插入一棵初始为空的二叉排序树,画出插入完成之后的二叉排序树,并求其在等概率的情况下查找成功的平均查找长度。 若对表中元素先进行排序构成有序表,求在等概率的情况下对此有序表进行折半查找时查找成功的平均查找长度。 按表中元素顺序构造一棵平衡二叉排序树,并求其在等概率的情况下查找成功的平均查找长度。解: 堆排序第一步,形成初始大根堆(详细过程略),第二步做堆排序。1221620103016*28618302816102016*182126初始排序 不是大根堆 形成初始大根堆1228162102016*18630282016101216*182306交换1与10对象 从1到9重新形成堆620162101216*182830201816101216*623028交换1与9对象 从1到8重新形成堆2181620101216*6283018121610216*12203028交换1与8对象 从1到7重新形成堆16*121620102186283016*12161021862030

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 社会民生

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