网站大量收购闲置独家精品文档,联系QQ:2885784924

《算法与数据结构》模拟试题5--答案.doc

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
《算法与数据结构》模拟试题5--答案.doc

《算法与数据结构》模拟试题5(参考答案) 一、填空题(每小题2分,共18分) 1、 线性结构 树形结构 图(或网)状结构 2、 时间复杂度 空间复杂度 3、 物理上的相邻 指针 4、 操作受限 后进先出(先进后出) 5、 1340 6、左子树 右子树 7、 顶点数 对称矩阵 8、 顺序存储且有序 散列存储 9、索引 散列 二、单项选择题(请将答案写在题目后的括号中。每题2分,共18分) 题号 1 2 3 4 5 6 7 8 9 答案 A C D B D D B C A 三、分析题(每题6分,共30分) 1、 解:所构造的Huffman树如下图所示。 WPL=(19+21+32)×2+(6+7+10)×4+(2+3)×5 =261 2、 解:该网的邻接链表如下图所示: 从顶点V1出发的广度优先搜索的顶点序列是1→2→4→5→3,相应的生成树如下: 3、 解:将关键字序列(15,21,13,7,4,9,25,19,)T的过程如图(a)所示;删除13之后的二叉排序树T1如图(b)所示。 4、 解:根据所给定的散列函数和处理冲突方法,得到的散列表结构如下: 成功查找的平均查找长度:ASL=(1×8+2×2+3×1)/11=17/11 5、 解:采用增量序列为5, 3, 1的希尔排序法,做非递减排序时的每一趟结果如下: 四、算法填空(每空2分,共20分) 请在下面各算法的空白处填上相应语句实现算法功能。每个空白处只能填一个语句。 1、头插入法创建单链表,以整数的最大值(32767)作为输入结束,链表的头结点head作为返回值。 P= (LNode *)malloc(sizeof(LNode)) p–next= head–next 2、按满二叉树的方式对结点进行编号建立链式二叉树。对每个结点,输入结点i、结点ch。 p–Lchild=p–Rchild=NULL i%2==0 s[j]-Rchild=p 3、v出发,递归地深度优先搜索图G。 p=G-AdjList[v].firstarc DFS(G, p-adjvex) p=p-nextarc 4、 冒泡排序算法。 L-R[k].keyL-R[k+1].key flag==TRUE 五、编写算法(要求给出相应的数据结构说明,14分) 解:结点类型定义及算法如下: #define Max_Node_Num 50 Typedef struct BTNode { ElemType data ; /* 数据域,保存结点的值 */ struct BTNode *Lchild , *Rchild ; /* 指针域 */ }BTNode ; /* 结点的类型 */ Void count_node_num( BTNode *T) { BTNode *Stack[Max_Node_Num] ,*p=T, *q ; int top=0 , leaf_num=0 , num1=0 ; if (T==NULL) printf(“The Binary Tree is Empty!\n”) ; else { do { if ( !(p-Lchild!=NULL p-Rchild!=NULL) ) { if (p-Lchild==NULL p-Rchild==NULL) leaf_num++ ; else num1++ ; } q=p-Rchild ; if ( q!=NULL ) stack[++top]=q ; p=p-Lchild ; if (p==NULL) { p=stack[top] ; top-- ; } } while (p!=NULL) ; printf(“度为1和0的结点数分别是: %d, %d\n”, num1,leaf_num) ; } } 1 21 9 23 25 15 13 11 7 15 19 32 60 21 28 21 13 10 7 7 图(a) 生成的二叉排序树T的过程 21 9 15 3 5 2 21 40 13 7 15 100 21 0 1 3 2 4 1 7 2 4 3 5 3 1 8 ∧ 6 4 ∧ 11 4 4 2 8 0 10 3 ∧ 3 ∧ 3 3 7 0 4 1 4 3 2 10 1 ∧ 6 0 3 3 11 1 4 6 从顶点V1出发广度优先搜索生成树 图(b) 删除13后的二叉排序树 按Kruskal算法得到的最小生成树 3 4 3 9 19 6 4 1

文档评论(0)

资料 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档