1下述哪一条是顺序存储结构的优点

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

第2章线性表

一选择题

1.下述哪一条是顺序存储结构的优点?()

A.存储密度大 B.插入运算方便 C.删除运算方便 D.可方便地用于各种逻辑结构的存储表示

2.下面关于线性表的叙述中,错误的是哪一个?()

A.线性表采用顺序存储,必须占用一片连续的存储单元。

B.线性表采用顺序存储,便于进行插入和删除操作。

C.线性表采用链接存储,不必占用一片连续的存储单元。

D.线性表采用链接存储,便于插入和删除操作。

3.线性表是具有n个()的有限序列()。

A.表元素 B.字符 C.数据元素 D.数据项 E.信息项4.若某线性表最常用的操作是存取任一指定序号的元素和在最后进行插入和删除运算,则利用()存储方式最节省时间。

A.顺序表 B.双链表 C.带头结点的双循环链表 D.单循环链表5.某线性表中最常用的操作是在最后一个元素之后插入一个元素和删除第一个元素,则采用()存储方式最节省运算时间。

A.单链表 B.仅有头指针的单循环链表 C.双链表 D.仅有尾指针的单循环链表

6.设一个链表最常用的操作是在末尾插入结点和删除尾结点,则选用( )最节省时间。

A. 单链表

B.单循环链表

C. 带尾指针的单循环链表

D.带头结点的双循环链表

7.若某表最常用的操作是在最后一个结点之后插入一个结点或删除最后一个结点。则采用()存储方式最节省运算时间。

A.单链表 B.双链表 C.单循环链表 D.带头结点的双循环链表

8. 链表不具有的特点是()

A.插入、删除不需要移动元素 B.可随机访问任一元素

C.不必事先估计存储空间 D.所需空间与线性长度成正比

9. 下面的叙述不正确的是()

A.线性表在链式存储时,查找第i个元素的时间同i的值成正比

B. 线性表在链式存储时,查找第i个元素的时间同i的值无关

C. 线性表在顺序存储时,查找第i个元素的时间同i 的值成正比

D. 线性表在顺序存储时,查找第i个元素的时间同i的值无关

静态链表既有顺序存储的优点,又有动态链表的优点。所以,它存取表中第i个元素的时间与i无关。

(2) 静态链表中能容纳的元素个数的最大数在表定义时就确定了,以后不能增加。

(3) 静态链表与动态链表在元素的插入、删除上类似,不需做元素的移动。

以上错误的是()

A.(1),(2) B.(1) C.(1),(2),(3) D.(2)

11. 若长度为n的线性表采用顺序存储结构,在其第i个位置插入一个新元素的算法的时间复杂度为()(1<=i<=n+1)。

A. O(0)

B. O(1)

C. O(n)

D. O(n2)

12. 对于顺序存储的线性表,访问结点和增加、删除结点的时间复杂度为()。

A.O(n) O(n) B. O(n) O(1) C. O(1) O(n) D. O(1) O(1) 13.线性表( a1,a2,…,an)以链接方式存储时,访问第i位置元素的时间复杂性为()A.O(i) B.O(1) C.O(n) D.O(i-1)

14.非空的循环单链表head的尾结点p↑满足()。

A.p↑.link=head B.p↑.link=NIL C.p=NIL D.p= head 15.循环链表H的尾结点P的特点是()。

A.P↑.NEXT=H B.P↑.NEXT= H↑.NEXT C.P=H D.P=H↑.NEXT 16.在一个以 h 为头的单循环链中,p 指针指向链尾的条件是()

A. p↑.next=h

B. p↑.next=NIL

C. p↑.next.↑next=h

D. p↑.data=-1

17.完成在双循环链表结点p之后插入s的操作是();

A. p↑.next:=s ; s↑.priou:=p; p↑.next↑.priou:=s ; s↑.next:=p↑.next;

B. p↑.next↑.priou:=s; p↑.next:=s; s↑.priou:=p; s↑.next:=p↑.next;

C. s↑.priou:=p; s↑.next:=p↑.next; p↑.next:=s; p↑.next↑.priou:=s ;

D. s↑.priou:=p; s↑.next:=p↑.next; p↑.next↑.priou:=s ; p↑.next:=s;

18.在双向循环链表中,在p指针所指向的结点前插入一个指针q所指向的新结点,其修改指针的操作是( )。

注:双向链表的结点结构为(llink,data,rlink)。供选择的答案:

A. p↑.llink:=q; q↑.rlink:=p; p↑.llink↑.rlink:=q; q↑.llink:=q;

B. p↑.llink:=q; p↑.llink↑.rlink:=q ; q↑.rlink:= p; q↑.llink:=p ↑.llink;

C. q↑.rlink:=p; q↑.llink:=p↑.llink; p↑.llink↑.rlink:=q; p↑.llink:=q;

D. q↑.llink:=p↑.llink;q↑.rlink:=p; p↑.llink:=q;p↑.llink:=q;(编者按:原题如此)

nk=p->Llink;q->Rlink=q;p->Llink=q;p->Llink=q;

19.在单链表指针为p的结点之后插入指针为s的结点,正确的操作是:()。

A.p->next=s;s->next=p->next; B. s->next=p->next;p->next=s;

C.p->next=s;p->next=s->next; D. p->next=s->next;p->next=s;

20.对于一个头指针为head的带头结点的单链表,判定该表为空表的条件是()A.head==NULL B.head→next==NULL C.head→next==head D.head!=NULL

21. 双向链表中有两个指针域,llink和rlink分别指向前趋及后继,设p指向链表中的一个结点,现要求删去p所指结点,则正确的删除是()(链中结点数大于2,p不是第一个结点)A.p↑.llink↑.rlink:=p↑.llink; p↑.llink↑.rlink:=p↑.rlink; free(p);

B.dispose(p); p↑.llink↑.rlink:=p↑.llink; p↑.llink↑,rlink:=p↑.rlink;

C.p↑.llink↑.rlink:=p↑.llink; free(p); p↑.llink↑.rlink:=p↑.rlink;

D.以上A,B,C都不对。

二、判断

1. 链表中的头结点仅起到标识的作用。( )

2. 顺序存储结构的主要缺点是不利于插入或删除操作。( )

3.线性表采用链表存储时,结点和结点内部的存储空间可以是不连续的。( )

4.顺序存储方式插入和删除时效率太低,因此它不如链式存储方式好。( )

5. 对任何数据结构链式存储结构一定优于顺序存储结构。( )

6.顺序存储方式只能用于存储线性结构。( )

7.集合与线性表的区别在于是否按关键字排序。( )

8. 所谓静态链表就是一直不发生变化的链表。( )

9. 线性表的特点是每个元素都有一个前驱和一个后继。( )

10. 取线性表的第i个元素的时间同i的大小有关. ( )

11. 循环链表不是线性表. ( )

12. 线性表只能用顺序存储结构实现。( )

相关文档
最新文档