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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

应用题复习含解.docx

1、应用题复习含解一、应用题1. 已知线性表的存储结构为顺序表,阅读下列算法,并回答问题:(1)设线性表L=(51,-9,-6,39,0,-11,34,70,-16),写出执行算法f11(&L)后的L状态;(2)简述算法f11的功能。void f11 (SeqList *L) int i,j;for (i=j=0;ilen; i+)if(L-elemi=0)if(i!=j)L-elemj=L-elemi;j+;L-len=j;【答案】(1)L=(51,39,0,34,70)(2) 删除顺序表中小于0的数。2. 假设以带头结点的单链表表示线性表,阅读下列算法f22,并回答问题:(1)设线性表为( a

2、1, a2, a3, a4, a5, a6, a7 ), 写出执行算法f22后的线性表;(2)简述算法f22的功能。 void fun(LNode *L)/L为带头结点单链表的头指针P =L;while (p &p-next)q = p-next;p-next =q-next;p =q-next;free(q); 【答案】(1)(a2,a4,a6)(2) 删除单链表中数据结点序号为奇数的那些结点。3.假设以数组seqnm存放循环队列的元素,设变量rear和quelen分别指示循环队列中队尾元素的位置和元素的个数。(1)写出队满的条件表达式;(2)写出队空的条件表达式;(3)设m=50,rear

3、=19,quelen=25,求队头元素的位置;(4)写出一般情况下队头元素位置的表达式。【答案】(1)quelen=m(2)quelen=0(3)45(4)front=(rear-quelen+1+m)%m4.假设以数组seqnm存放循环队列的元素,设变量front和rear分别指示循环队列中队头元素的位置和队尾元素的位置。(1)写出队满的条件表达式;(2)写出队空的条件表达式;(3)设m=40,rear=13,front=19,求队列的元素的个数quelen;(4)写出一般情况下元素的个数的表达式。【答案】(1)(rear+1)%m=front(2) rear=front(3)34(4) q

4、uelen=(rear-frontm)%m5. 假设有一个如下图的88矩阵,矩阵元素都是整型量(次对角线以上的元素都是0)。若将上述矩阵中次对角线及其以下的元素按行优先压缩存储在一维数组B中,请回答下列问题:(1)B数组的体积至少是多少?(2)若a18存储在B0中,a56存储在Bk中,则k值为多少?(1) (2)【答案】(1)36 (2)136. 阅读下列算法,并回答问题:(1)Q、Q1和Q2都是队列结构,设队列Q=(1,0,-5,2,-4,-6,9),其中1为队头元素,写出执行f33 (&Q,&Q1,&Q2)之后队列Q、Q1和Q2的状态;(2)简述算法f33的功能。(注:lnitQueue、

5、EnQueue、DeQueue和QueueEmpty分别是队列初始化、入列、出队和判队空的操作)void f31 (Queue*Q, Queue*Q1, Queue*Q2) int e;lnitQueue (Q1);lnitQueue (Q2);while (!QueueEmpty (Q) e=DeQueue (Q);if (e=0) EnQueue (Q1,e);else EnQueue (Q2,e)【答案】(1)Q=() Q1=(1,0,2,9) q2=(-5,-4,-6)(2)将Q队列中的数据全部出队;不小于0的进Q1,否则进Q2。7. 已知二叉树如右图所示。(1)画出该二叉树的二叉链表

6、;(2)分别写出该二叉树的先根、中根和后根遍历序列。【答案】 (1) 二叉链表:(2)先根遍历序列:ABDCEGF中根遍历序列: DBAEGCF后根遍历序列: DBGEFCA8、假设一棵二叉树的先根遍历序列为ABCDEFGH,中根遍历序列为CDBEGFHA。(1)画出该二叉树;(2)写出后根遍历序列。【答案】(1)二叉树(2)后根遍历序列:DCGHFEBA9、假设一棵二叉树的中根遍历序列为DGBEACHFI,后根遍历序列为GDEBHIFCA(1)画出该二叉树;(2)写出先根遍历序列。【答案】(1)二叉树:(2)先根遍历序列:ABDGECFHI10假设一棵二叉树的层次遍历序列为ABCDEFGHI

7、,中根遍历序列为DHBEAFCIG。(1)画出该二叉树;(2)写出先根和后根遍历序列。【答案】(1)二叉树:(2)先根遍历序列:ABDHECFGI后根遍历序列:HDEBFIGCA11设某通讯系统仅用七个英文字符A,D,G,H,M,S,T,每个字符的使用频率分别为3,7,18,2,6,10,14。请画出对应的哈夫曼编码树(按照每个结点的左子树根结点的权小于等于右子树根结点的权的次序构造),并求出每个字符的哈夫曼编码。【答案】哈夫曼编码ADGHMST00011001100000011010112. 假设通信电文使用的字符集为 S,T,B,F,C,字符的哈夫曼编码依次为:011,10,00,010和

8、11。 (1)请根据哈夫曼编码画出此哈夫曼树,并在叶子结点中标注相应字符; (2)若这些字符在电文中出现的频度分别为:4,7,5,2和9,求出电文的总长度。【答案】(1)编码哈夫曼树 (2) 电文的总长度=4*3+7*2+5*2+2*3+9*2=6013、已知一个有向图如右图所示。(1)试画出它的邻接表。(表结点按顶点编号递减排列)(2)分别求出从v1出发按深度优先搜索和广度优先搜索算法遍历得到的顶点序列。【答案】(1) (2)深度优先搜索序列:v1,v 4,v 3, v 5,v 2 广度优先搜索序列:v1,v 4,v 3, v 2,v 514、已知一个AOV网如右图所示。 (1)试画出它的邻

9、接链表。(表结点按顶点编号递减排列)(2)试写出按照拓扑排序算法得到的拓扑序列。【答案】 (1) (2)v2,v5,v1,v3,v6,v415、请用普里姆算法(从顶点V3开始)和克鲁斯卡尔算法构造下图所示网络的最小生成树,按照并入最小生成树中边的次序填写下表,并画出最小生成树。次序1 2 345始 点 终 点权 值【答案】(1)普里姆算法构造过程: 最小生成树:次序1 2 345始 点V3V1V3V2V2终 点V1V4V2V5V6权 值121416810(2)克鲁斯卡尔算法构造过程: 最小生成树:次序1 2 345始 点V2V2V3V1V3终 点V5V6V1V4V2权 值81012141616

10、、设关键字序列(17,8,13,25,24,16,3,19,1),写出用下列方法排序时,第一趟结束时关键字的排列状态。(1)冒泡排序 (2)希尔排序(d1=4) (3)快速排序【答案】 (1)冒泡排序 (8,13,17,24,16,3,19,1,25)(2)希尔排序(d1=4) (1,8,3,19,17,16,13,25,24)(3)快速排序(1,8,13,3,16)17(24,19,25)17、对有序表12,24,30,46,52,61,70,79,83进行折半查找方法查找,(1)求出查找24和83时所需比较的次数;(2)画出判定树; (3)求ASL和MSL。【答案】(1)24比较2次;83

11、比较4次(2)判定树:(3)ASL=(1+4+12+8)/9=25/9=2.78MSL=418已知一组数据元素为(68,21,95,71,14,57,28,33,80),要求:(1)试从空树开始画出按元素排列顺序输入而生成的一棵二叉排序树;(2)画出删除结点68后的二叉排序树。【答案】(1) 二叉排序树:(2)删除结点68后的二叉排序树:19.选取哈希函数为H(K)=K % 7。用线性探测的开放地址法处理冲突。试在08的散列地址空间中对关键字序列25,72,48,19,32,50,68构造哈希表,并求出等概率下查找成功的平均查找长度。【答案】 (1) 哈希表: 比较次数: 1 1 1 1 1

12、4 4(2)20. 下列是一棵五阶B-树,依次执行以下两步操作,画出每一步执行后所得到的B-树形。(1)插入n;(2)删除e 。【答案】(1)插入n: (2)删除e:21已知关键字序列为:(70,31,52,41, 88,12,27,66)哈希表长为9,哈希函数为:H (k)k %9,用链地址法处理冲突,试构造哈希表,并求等概率下查找成功的平均查找长度。【答案】(1)哈希表: (2) 22. 由森林转换得到的对应二叉树如图所示,写出原森林中第三棵树的前序序列和后序序列。【答案】还原后的森林:第三棵树的前序序列GHIJ ;后序序列HJIG23. 假设一棵树的先根序列为ABCEFIJGHKD,后根

13、序列为BEIJFGKHCDA。请画出该树。【答案】(1)因为树的先根和后根遍历序列分别与其转换后对应的二叉树的先根和中根遍历序列相同,所以可先得到的对应的二叉树如下图所示:(2)根据树与二叉树的转换规则,可得到树如下图所示:24. 已知一个散列表如下图所示:19 32485822 0 1 2 3 4 5 6 7 8 9 10 11 12 其散列函数为h(key)=key%13, 处理冲突的方法为双重散列法,探测序列为: hi=(h(key)+i *h1(key)%m i=1,,m1其中 h1(key)=key%11+1回答下列问题:(1)对表中关键字19,32和22进行查找时,所需进行的比较次

14、数各为多少?(2)该散列表在等概率查找时查找成功的平均查找长度为多少?【答案】()对关键字19,32和22进行查找的比较次数为、3; ()平均查找长度H(32)=32%13=6 比较1次H(48)=48%13=9 比较1次H(58)=58%13=6(冲突) h1=58%11+1=4H1(58)=(6+4)%13=10(成功) 比较2次H(22)=22%13=9(冲突) h1=22%11+1=1H1(22)=(9+1)%13=10(冲突)H2(22)=(9+2*1)%13=11(成功) 比较3次H(19)=19%13=6(冲突) h1=19%11+1=9H1(19)=(6+9)%13=2(成功) 比较2次

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

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