2019-2020学年数据结构期末试题与答案.docVIP

2019-2020学年数据结构期末试题与答案.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第 PAGE 6 第 PAGE 6 页,共 NUMPAGES 6 页 仲 恺 农 业 工 程 学 院 试 卷 (答案及评分标准) 《数据结构与算法》 2011至 2012 学年度第 2 学期期 末 (A)卷 专业班级 姓名 学号 题 号 一 二 三 四 五 六 七 八 合计 得 分 评卷人 (考生注意:考试时间为120分钟。答案须写在答题纸上,并注明题号,考试结束后将试卷连同答题纸一齐交) 一、选择题(每小题选出一个最合适的答案,共30分) 1、在以单链表为存储结构的线性表中,数据元素之间的逻辑关系用( C ) A.数据元素的相邻地址表示 B.数据元素在表中的序号表示 C.指向后继元素的指针表示 D.数据元素的值表示 2、线性表采用链式存储时,结点的存储地址( B ) A.必须是不连续的 B.连续与否均可 C.必须是连续的 D.和头结点的存储地址相连续 3、设数组data[m]作为循环队列SQ的存储空间,front为队头指针,rear为队尾指针,则执行出队操作后其头指针front值为( D ) A.front=front+1 B.front=(front+1)%(m-1) C.front=(front-1)%m D.front=(front+1)%m 4、设有一个顺序栈S,元素s1,s2,s3,s4,s5,s6依次进栈,如果6个元素的出栈顺序为s2,s3,s4,s6,s5,s1,则顺序栈的容量至少应为多少( C ) A.1 B.2 C.3 D.4 5、栈和队列都是( A ) A.限制存取位置的线性结构 B.顺序存储的线性结构C.链式存储的线性结构D.限制存取位置的非线性结构 6、现有一“遗传”关系:设x是y的父亲,则x可以把它的属性遗传给y。表示该遗传关系最适合的数据结构为( B ) A.线性表 B.树 C.图 D.二叉树 7、下列陈述中正确的是( D ) A.二叉树是度为2的有序树 B.二叉树中结点只有一个孩子时无左右之分 C.二叉树中必有度为2的结点 D.二叉树中最多只有两棵子树,并且有左右之分 8、在具有n个叶子结点的严格二叉树(即结点的度要么是0要么是2)中,结点总数为( C ) A.2n+1 B.2n C.2n-1 D.2n-2 9、N个顶点的有向完全图中含有有向边的数目最多为( D ) A.N-1 B.N C.N(N-1)/2 D.N(N-1) 10、在含n个顶点和e条边的无向图的邻接矩阵中,零元素的个数为( D ) A.e B.2e C.n2-e D.n2-2e 二、填空题(每小题4分,共20分) 1、栈顶的位置是随着 进栈和出栈 操作(栈操作)而变化的。 2、对于单链表形式的队列,其空队列的front指针和rear指针都等于头结点的地址 。 3、n个记录的折半查找,若查找失败,进行了 [log2n]+1 次比较。 4、从顺序表中删除一个元素时,表中所有在被删元素之后的元素均需 向前移动 一个位置。 5、在队列中,允许进行插入操作的一端称为 队尾 ,允许进行删除操作的一端称为 队头 。 三、给出线性表的单链表存储结构,并实现用e返回线性表中第i个元素的值(即编写完整的函数GetElem(L,i,e),这里只给出函数的名称和参数名,未给出类型)。(10分) typedef struct LNode{ ElemType data; struct LNode *next; }LNode,*LinkList; Status GetElem(LinkList L,int i,ElemType e){ LinkList p; int j; p=L-next; j=1; while(pji){ p=p-next; ++j; } if(!p||ji)return ERROR; e=p-data; return OK; } 四、给出单链队列的存储结构(数据类型名为LinkQueue),下面是入队函数,但有缺漏,请补全(说明在哪一行补什么内容)。(10分) Status EnQueue(LinkQueue Q,e) {p=new QNode; if(!p) return 0; p—data=e; Q.rear—=p; return 1;} typedef struct QNode{ QElemType data; struct QNode *next; }QNode,*QueuePtr; typedef struct{ QueuePtr front; QueuePtr rear

文档评论(0)

潮起潮落 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档