数据结构作一满分版.docVIP

  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文档。上传文档
查看更多
数据结构作一满分版

1.???????在线性表的下列存储结构中,读取元素花费的时间最少的是 A.??????单链表??B.?双向链表??C.循环链表??D.顺序表 说明:顺序表总从链表访问快,因为顺序表元素都是按顺序排列在一起的。而链表的元素是分散的,要访问它的某一个元素,必须先访问它前面的元素。 ? 2.???????顺序表是线性表的? A.链式存储结构??????B.????顺序存储结构??????C.?索引存储结构??D.散列存储结构 说明:顺序存储指在内存中是一个连续的整块,这是定义,没啥说的。 ? 3.?以下关于线性表的说法不正确的是( )。?? A、线性表中的数据元素可以是数字、字符、记录等不同类型。 B、线性表中包含的数据元素个数不是任意的。?? C、线性表根据存储结构分可以有顺序表、链表、动态表 D、存在这样的线性表:表中各结点都没有直接前趋和直接后继 说明:A,我认为可以是任何类型(暂时没想出反例) B,这句话不太好理解,估计原题的意思是为了说明:线性表是能得到确切的元素个数。 C,线性表只包括顺序表和链表。而动态表,没听说过这种说法。 D,线性表为空,好像就符合题意。 4.在顺序表中,只要知道( ),就可在相同时间内求出任一结点的存储地址。 A)?基地址??????B)?结点大小?????C)?向量大小?????D)基地址和结点大小 说明:这里任意结点是指给出这个结点的索引(index),则其地址为:base + index * sizeof(node),这里base为基地址,sizeof(node)为结点大小,假设index从0开始计数(C/C++都是从0开始,如果其它语言从1开始,只要将index-1代替index就可以了) 5.在等概率情况下,顺序表的插入操作要移动( )结点。 A)?全部???????????????B)?一半?????????C)?三分之一???????????????D)?四分之一 说明:插入和删除操作,平均约要移动全部元素的1/2,在P25,有推导公式,记住结果就行了。 6.在( )运算中,使用顺序表比链表好。?? A)?插入?????????B)?删除???????????????C)?根据序号查找???????????????D)??根据元素值查找 说明:插入、删除操作都是链表快。根据元素值查找,都是要遍历每个元素,进行比对,直到找到为止,两者效率应该相等。根据序号查找,也就是根据索引index,顺序表的访问时间为常量,比链表要快,这与第4题是同一个知识点。 7.在一个具有n个结点的有序单链表中插入一个新结点并仍然有序的时间复杂度是( )。?? A)??O(1)??????????????B)??O(n)??????????????C)??O(n^2)??????????D)??O(log2n) 说明:插入前要遍历之前的每一个元素,直到找到位置为止,这个定位过程,都是O(n) 8.( )适合作为经常在首尾两端操作线性表的存储结构。?? A)??顺序表????B)?单链表?????????C)?循环链表?????????D)?双向链表 说明:常用操作无非包括插入、删除、读取三种方式。 顺序表的插入效率太低,不予考虑。 对于BCD三种链表(循环链表没说是双向的,我们这里只认为是普通方式,即单向循环)。对首端的操作差不多。但对尾端就不一样了。比如要删除尾结点t?,则必须先找到它的前一个结点s。前两者,只有遍历整个链表,才能找到s。而在双向链表中,只要用s = t-prior就可以表示它的前一个结点了。 9.?非空的循环单链表head的尾节点(由r所指向)满足 A)?????r-next=NULL???????B)????r=NULL?????????C)????r-next=head?????????D)???r=head 说明:这是定义,最后一个结点的下一结点为头结点。 ? 10.设线性表(a1,a2,a3···an)按顺序存储,且每个元素占有m个存储单元,则元素ai的地址为 A??????LOC(a1) + i×m?,其中LOC(a1)表示元素a1的地址 B??????LOC(a1) + (i-1)×m, C??????LOC(a1) + (i-2)×m D??????元素ai的地址无法计算 说明:见第4题,这里从1开始,所以要减去1 11.线性表若采用链式存储结构时,要求内存中可用存储单元的地址?? A)????必须是连续的?????????????B)??部分地址必须是连续的 C)????一定是不连续的???????????D)??连续或不连续都可以 说明:其每个结点的地址,都是malloc()出来的,这是系统调用,可能连续也可能不连续,不过一般情况下,都是不连续的。 12.?下列图1单链

文档评论(0)

mhk8089 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档