线性表练习题Word下载.docx
- 文档编号:22966837
- 上传时间:2023-02-06
- 格式:DOCX
- 页数:21
- 大小:29.96KB
线性表练习题Word下载.docx
《线性表练习题Word下载.docx》由会员分享,可在线阅读,更多相关《线性表练习题Word下载.docx(21页珍藏版)》请在冰豆网上搜索。
A.插入、删除不需要移动元素B.可随机访问任一元素
C.不必事先估计存储空间D.所需空间与线性长度成正比
10.下面的叙述不正确的是()
【南京理工大学1996】
A.线性表在链式存储时,查找第i个元素的时间同i的值成正比
B.线性表在链式存储时,查找第i个元素的时间同i的值无关
C.线性表在顺序存储时,查找第i个元素的时间同i的值成正比
D.线性表在顺序存储时,查找第i个元素的时间同i的值无关
11.
(1)静态链表既有顺序存储的优点,又有动态链表的优点。
所以,它存取表中第i个元素的时间与i无关。
(2)静态链表中能容纳的元素个数的最大数在表定义时就确定了,以后不能增加。
(3)静态链表与动态链表在元素的插入、删除上类似,不需做元素的移动。
以上错误的是()
【南京理工大学2000】
A.
(1),
(2)B.
(1)C.
(1),
(2),(3)D.
(2)
12.若长度为n的线性表采用顺序存储结构,在其第i个位置插入一个新元素的算法的时间复杂度为()(1<
=i<
=n+1)。
【北京航空航天大学1999】
A.O(0)B.O
(1)C.O(n)D.O(n2)
13.对于顺序存储的线性表,访问结点和增加、删除结点的时间复杂度为()。
A.O(n)O(n)B.O(n)O
(1)C.O
(1)O(n)D.O
(1)O
(1)
14.线性表(a1,a2,…,an)以链接方式存储时,访问第i位置元素的时间复杂性为()。
A.O(i)B.O
(1)C.O(n)D.O(i-1)
【中山大学1999】
15.非空的循环单链表head的尾结点p满足()。
【武汉大学2000】
A.p->
link=headB.p->
link=NILC.p=NILD.p=head
16.循环链表H的尾结点P的特点是()。
【中山大学1998二、2(2分)】
A.P->
NEXT=HB.P->
NEXT=H->
NEXTC.P->
HD.P=H->
NEXT
17.在一个以h为头的单循环链中,p指针指向链尾的条件是()
【南京理工大学1998】
A.p->
next=hB.p->
next=NILC.p->
next->
next=hD.p->
data=-1
18.完成在双循环链表结点p之后插入s的操作是();
【北方交通大学1999】
A.p->
next=s;
s->
priou=p;
p->
priou=s;
next=p->
next;
B.p->
priou=s;
next:
=s;
C.s->
next=s;
D.s->
19.在双向循环链表中,在p指针所指向的结点前插入一个指针q所指向的新结点,其修改指针的操作是()。
【北京邮电大学1998】
注:
双向链表的结点结构为(llink,data,rlink)。
供选择的答案:
llink=q;
q->
rlink=p;
llink->
rlink=q;
rlink=q;
q->
rlink=p;
llink=p->
llink;
C.q->
rlink=q;
llink=q;
D.q->
p->
20.在非空双向循环链表中q所指的结点前插入一个由p所指的链结点的过程依次为:
rlink(p)←q;
llink(p)←llink(q);
llink(q)←p;
()
A.rlink(q)←pB.rlink(llink(q))←pC.rlink(llink(p))←p
D.rlink(rlink(p))←p【北京航空航天大学2000】
21.双向链表中有两个指针域,llink和rlink,分别指回前驱及后继,设p指向链表中的一个结点,q指向一待插入结点,现要求在p前插入q,则正确的插入为()
【南京理工大学1996】
rlink=p;
llink;
B.q->
llink=q->
rlink;
C.q->
D.p->
22.在双向链表指针p的结点前插入一个指针q的结点操作是()。
【青岛大学2000】
Llink=q;
Rlink=p;
Llink->
Rlink=q;
Llink=q;
B.p->
Llink=p->
Llink;
D.q->
23.在单链表指针为p的结点之后插入指针为s的结点,正确的操作是:
()。
s->
B.s->
C.p->
next=s->
D.p->
【青岛大学2001】
24.对于一个头指针为head的带头结点的单链表,判定该表为空表的条件是()
【北京工商大学2001】
A.head==NULLB.head→next==NULLC.head→next==headD.head!
=NULL
25.在双向链表存储结构中,删除p所指的结点时须修改指针()。
A.(p->
llink)->
rlink=p->
rlink(p->
rlink)->
llink=(p->
llink(p->
llink)->
C.(p->
llink=pp->
rlink=(p->
rlink
D.p->
llinkp->
【西安电子科技大学1998】
26.双向链表中有两个指针域,llink和rlink分别指向前趋及后继,设p指向链表中的一个结点,现要求删去p所指结点,则正确的删除是()(链中结点数大于2,p不是第一个结点)
free(p);
B.free(p);
D.以上A,B,C都不对。
【南京理工大学1997】
二、判断
1.链表中的头结点仅起到标识的作用。
()
【南京航空航天大学】
2.顺序存储结构的主要缺点是不利于插入或删除操作。
()
【南京航空航天大学1997】
3.线性表采用链表存储时,结点和结点内部的存储空间可以是不连续的。
4.顺序存储方式插入和删除时效率太低,因此它不如链式存储方式好。
】2002【北京邮电大学.
5.对任何数据结构链式存储结构一定优于顺序存储结构。
【南京航空航天大学1997】
6.顺序存储方式只能用于存储线性结构。
【中科院软件所1999】【上海海运学院1997】
7.集合与线性表的区别在于是否按关键字排序。
【大连海事大学2001】
8.所谓静态链表就是一直不发生变化的链表。
9.线性表的特点是每个元素都有一个前驱和一个后继。
【合肥工业大学2001】
10.取线性表的第i个元素的时间同i的大小有关.()
【南京理工大学1997】
11.循环链表不是线性表.()
【南京理工大学1998】
12.线性表只能用顺序存储结构实现。
13.线性表就是顺序存储的表。
【青岛大学2002】
14.为了很方便的插入和删除数据,可以使用双向链表存放数据。
【上海海运学院1995】【上海海运学院1997】
15.顺序存储方式的优点是存储密度大,且插入、删除运算效率高。
【上海海运学院1996】【上海海运学院1999】
16.链表是采用链式存储结构的线性表,进行插入、删除操作时,在链表中比在顺序存储结构中效率高。
()【上海海运学院1998】
三、填空
1.当线性表的元素总数基本稳定,且很少进行插入和删除操作,但要求以最快的速度存取线性表中的元素时,应采用_______存储结构。
2.线性表L=(a1,a2,…,an)用数组表示,假定删除表中任一元素的概率相同,则删除一个元素平均需要移动元素的个数是________。
3.设单链表的结点结构为(data,next),next为指针域,已知指针px指向单链表中data为x的结点,指针py指向data为y的新结点,若将结点y插入结点x之后,则需要执行以下语句:
_______;
______;
【华中理工大学2000】
4.在一个长度为n的顺序表中第i个元素(1<
=n)之前插入一个元素时,需】2001【北京工商大学个元素。
________向后移动.
5.在单链表中设置头结点的作用是________。
【哈尔滨工业大学2000】
6.对于一个具有n个结点的单链表,在已知的结点*p后插入一个新结点的时间复杂度为________,在给定值为x的结点后插入一个新结点的时间复杂度为________。
7.根据线性表的链式存储结构中每一个结点包含的指针个数,将线性链表分成________和_______;
而又根据指针的连接方式,链表又可分成________和________。
【西安电子科技大学1998】
8.在双向循环链表中,向p所指的结点之后插入指针f所指的结点,其操作是_______、_______、_______、________。
【中国矿业大学2000】
9.在双向链表结构中,若要求在p指针所指的结点之前插入指针为s所指的结点,则需执行下列语句:
【福州大学1998】
next=p;
prior=________;
prior=s;
________=s;
10.链接存储的特点是利用________来表示数据元素之间的逻辑关系。
【中山大学1998】
11.顺序存储结构是通过________表示元素之间的关系的;
链式存储结构是通过________表示元素之间的关系的。
【北京理工大学2001】
12.对于双向链表,在两个结点之间插入一个新结点需修改的指针共______个,单链表为_______个。
13.循环单链表的最大优点是:
________。
14.已知指针p指向单链表L中的某结点,则删除其后继结点的语句是:
________
【合肥工业大学1999】
15.带头结点的双循环链表L中只有一个元素结点的条件是:
【合肥工业大学1999、2000】
16.在单链表L中,指针p所指结点有后继结点的条件是:
__
【合肥工业大学2001】
17.带头结点的双循环链表L为空表的条件是:
【北京理工大学2000】【青岛大学2002】
18.在单链表p结点之后插入s结点的操作是:
_______。
应用题四
1.线性表有两种存储结构:
一是顺序表,二是链表。
试问:
(1)如果有n个线性表同时并存,并且在处理过程中各表的长度会动态变化,线性表的总数也会自动地改变。
在此情况下,应选用哪种存储结构?
为什么?
(2)若线性表的总数基本稳定,且很少进行插入和删除,但要求以最快的速度存取线性表中的元素,那么应采用哪种存储结构?
为什么?
【西安电子科技大学1999软件二、1(5分)】
2.线性表的顺序存储结构具有三个弱点:
其一,在作插入或删除操作时,需移动大量元素;
其二,由于难以估计,必须预先分配较大的空间,往往使存储空间不能得到充分利用;
其三,表的容量难以扩充。
线性表的链式存储结构是否一定都能够克服上述三个弱点,试讨论之。
【重庆大学2000二、5】
3.若较频繁地对一个线性表进行插入和删除操作,该线性表宜采用何种存储结构?
【北京航空航天大学1998一、2(4分)】
。
线性表的存储结构分成______________和______、______、4.线性结构包括分)】一、19992(10______和______。
【华北计算机系统工程研究所〉的物理(1<
n)用顺序映射表示时,ai和ai+15.线性表(a1,a2,…,an分)】1(5位置相邻吗?
链接表示时呢?
【东南大学1996一、说明在线性表的链式存储结构中,头指针与头结点之间的根本区别;
头结点6.
】
(14%/3分)与首元结点的关系。
【厦门大学2000五、1
头指针这三个概念的区别。
首元结点,7.试述头结点】5分))】【西安电子科技大学2001计应用(【武汉交通科技大学1996(3分?
在单链表和双向链表中,能否从当前结点出发访问到任何一个结点8.分)】计应用一、1(5【西安电子科技大学1999如何通过改链的方法,把一个单向链表变成一个与原来链接方向相反的单向9.
(2分)4链表?
【中国人民大学2001二、所指结点的直接后p设单链表结点指针域为next,试写出删除链表中指针10.
3】2000C语言语句。
【北京科技大学一、继的,链指针域为data所指结点(即pp结点)的数据域为11.设单链表中某指针。
语句)结点之前插入ps结点的操作(C,请写出在next】分)2(2一、1999【北京科技大学.
12.有线性表(a1,a2,…,an),采用单链表存储,头指针为H,每个结点中存放线性表中一个元素,现查找某个元素值等于X的结点。
分别写出下面三种情况的查找语句。
要求时间尽量少。
(1)线性表中元素无序。
(2)线性表中元素按递增有序。
(3)线性表中元素按递减有序。
【北京邮电大学1994七(7分)】
13.设双向循环链表中结点的数据域、前驱和后继指针域分别为data,pre和next,试写出在指针p所指结点之前插入一s结点的C语言描述语句。
【北京科技大学2001一、3(2分)】
14.一线性表存储在带头结点的双向循环链表中,L为头指针。
如下算法:
(1)说明该算法的功能。
(2)在空缺处填写相应的语句。
voidunknown(BNODETP*L)
{…
p=L->
q=p->
r=q->
next;
while(q!
=L)
{while(p!
=L)&
&
(p->
data>
data)p=p->
prior;
prior->
next=r;
(1)______;
prior=p;
(2)______;
(3)______;
q=r;
p=q->
(4)______;
}
}【北京理工大学1999第二部分数据结构[7](8分)】
五、算法设计题
1.假设有两个按元素值递增次序排列的线性表,均以单链表形式存储。
请编写算法将这两个单链表归并为一个按元素值递减次序排列的单链表,并要求利用原来两个单链表的结点存放归并后的单链表。
【北京大学1998三、1(5分)】
类似本题的另外叙述有:
(1)设有两个无头结点的单链表,头指针分别为ha,hb,链中有数据域data,链域next,两链表的数据都按递增序存放,现要求将hb表归到ha表中,且归并后haha中的数据不归并到hb则,中也有hb表中已有的数据若ha归并中,仍递增序
中,hb的链表在算法中不允许破坏。
【南京理工大学1997四、3(15分)】
(2)已知头指针分别为la和lb的带头结点的单链表中,结点按元素值非递减有序排列。
写出将la和lb两链表归并成一个结点按元素值非递减有序排列的单链表(其头指针为lc),并计算算法的时间复杂度。
【燕山大学1998(20分)】
2.设带头结点且头指针为ha和hb的两线性表A和B分别表示两个集合。
两表中的元素皆为递增有序。
请写一算法求A和B的并集AUB。
要求该并集中的元素仍保持递增有序。
且要利用A和B的原有结点空间。
【北京邮电大学1992】
(1)已知递增有序的两个单链表A,B分别存储了一个集合。
设计算法实现求两个集合的并集的运算A=A∪B【合肥工业大学1999五、1(8分)】
(2)已知两个链表A和B分别表示两个集合,其元素递增排列。
编一函数,求A与B的交集,并存放于A链表中。
【南京航空航天大学2001六(10分)】
(3)设有两个从小到大排序的带头结点的有序链表。
试编写求这两个链表交运算的算法(即L1∩L2)。
要求结果链表仍是从小到大排序,但无重复元素。
【南京航空航天大学1996十一(10分)】
(4)己知两个线性表A,B均以带头结点的单链表作存储结构,且表中元素按值递增有序排列。
设计算法求出A与B的交集C,要求C另开辟存储空间,要求C同样以元素值的递增序的单链表形式存贮。
【西北大学2000五(8分)】
(5)已知递增有序的单链表A,B和C分别存储了一个集合,设计算法实现
A=A∪(B∩C),并使求解结构A仍保持递增。
要求算法的时间复杂度为O(|A|+|B|+|C|)。
其中,|A|为集合A的元素个数。
【合肥工业大学2000五、1(8分)】
3.知L1、L2分别为两循环单链表的头结点指针,m,n分别为L1、L2表中数据结点个数。
要求设计一算法,用最快速度将两表合并成一个带头结点的循环单链表。
【东北大学1996二(12分)】
(1)试用类C语言编写,实现连接线性表la和lb(lb在后)的算法,要求其时间复杂度为0
(1),占用辅助空间尽量小。
描述所用结构。
【北京工业大学1997】
为单向循环链表。
编写算法,将两个链hb为单向链表,ha)设有两个链表,2(.
表合并成一个单向链表,要求算法所需时间与链表长度无关。
【南京航空航天大学1997四(8分)】
4.顺序结构线性表LA与LB的结点关键字为整数。
LA与LB的元素按非递减有序,线性表空间足够大。
试用类PASCAL语言给出一种高效算法,将LB中元素合到LA中,使新的LA的元素仍保持非递减有序。
高效指最大限度的避免移动元素。
【北京工业大学1997一、2(12分)】
5.已知不带头结点的线性链表list,链表中结点构造为(data、link),其中data为数据域,link为指针域。
请写一算法,将该链表按结点数据域的值的大小从小到大重新链接。
要求链接过程中不得使用除该链表以外的任何链结点空间。
【北京航空航天大学1998五(15分)】
6.设L为单链表的头结点地址,其数据结点的数据都是正整数且无相同的,试设计利用直接插入的原则把该链表整理成数据递增的有序单链表的算法。
【东北大学1996六(14分)】
(1)设一单向链表的头指针为head,链表的记录中包含着整数类型的key域,试设计算法,将此链表的记录按照key递增的次序进行就地排序。
【中
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 线性 练习题