版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第2章 线 性 表典型例题解析一、选择题1线性表是具有n个(n0) 的有限序列。A表元素 B字符 C数据元素 D数据项【分析】线性表是具有相同数据类型的n(n0)个数据元素的有限序列,通常记为(a1,a2,an),其中n为表长,n=0时称为空表。【答案】C2顺序存储结构的优点是 。A存储密度大 B插入运算方便C删除运算方便 D可方便地用于各种逻辑结构的存储表示【分析】顺序存储结构是采用一组地址连续的存储单元来依次存放数据元素,数据元素的逻辑顺序和物理次序一致。因此,其存储密度大。【答案】A3带头结点的单链表head为空的判断条件是 。Ahead=NULL Bhead-next=NULLChea
2、d-next=head Dhead!=NULL【分析】链表为空时,头结点的指针域为空。【答案】B4若某线性表中最常用的操作是在最后一个元素之后插入一个元素和删除第一个元素,则采用 存储方式最节省运算时间。A单链表 B仅有头指针的单循环链表 C双链表 D仅有尾指针的单循环链表【分析】根据题意要求,该线性表的存储应能够很方便地找到线性表的第一个元素和最后一个元素,A和B都能很方便地通过头指针找到线性表的第一个元素,却要经过所有元素才能找到最后一个元素;选项C双链表若存为双向循环链表,则能很方便地找到线性表的第一个元素和最后一个元素,但存储效率要低些,插入和删除操作也略微复杂;选项D可通过尾指针直接
3、找到线性表的最后一个元素,通过线性表的最后一个元素的循环指针就能很方便地找到第一个元素。【答案】D5若某线性表最常用的操作是存取任一指定序号的元素和在最后进行插入和删除运算,则利用 存储方式最节省时间。A顺序表 B双链表C带头结点的双循环链表 D单循环链表【分析】某线性表最常用的操作是存取任一指定序号的元素和在最后进行插入和删除运算。因此不需要移动线性表种元素的位置。根据题意要求,该线性表的存储应能够很方便地找到线性表的任一指定序号的元素和最后一个元素,顺序表是由地址连续的向量实现的,因此具有按序号随机访问的特点。链表需要通过指针才能找到线性表的莫以指定序号的元素,需要一定的时间开销。【答案】
4、A6设一个链表最常用的操作是在末尾插入结点和删除尾结点,则选用 最节省时间。A. 单链表 B.单循环链表C. 带尾指针的单循环链表 D.带头结点的双循环链表【分析】根据题意要求,该线性表的存储应能够很方便地找到线性表的最后一个元素和最后一个元素的前驱元素,A和B都不能很方便地通过头指针找到线性表的第一个元素;选项C可以方便地找到最后一个元素,单不能很快地找到其前驱元素;选项D为双向循环链表,可以很方便地找到线性表的最后一个元素,通过其前驱指针,从而可以方便地找到其前驱元素。【答案】D7静态链表中指针表示的是 。A 内存地址 B数组下标 C下一元素地址 D左、右孩子地址【分析】静态链表采用的是链
5、式方式存储线性表,以数组方式存储链表的数据,指针域存储的是该结点逻辑上的后继结点的相对地址(即在数组中的下标),也称为静态指针。【答案】B8链表不具有的特点是 。A插入、删除不需要移动元素 B可随机访问任一元素 C不必事先估计存储空间 D所需空间与线性长度成正比【分析】链表是通过一组任意的存储单元来存储线性表中的数据元素的,为建立起数据元素之间的线性关系,对每个数据元素,除了存放数据元素自身的信息之外,还需要和存放其后继元素所在的存储单元的地址。链表不具有按序号随机访问第i个元素的特点,必须通过标识链表的头指针(或尾指针)“顺藤摸瓜”才能找到第i个结点。【答案】B9线性表的静态链表存储结构与顺
6、序存储结构相比优点是 。A所有的操作算法简单 B便于插入和删除C便于利用零散的存储器空间 D便于随机存取【分析】静态链表采用的是链式方式存储线性表,因此其具有链式存储的特点。【答案】B10若长度为n的线性表采用顺序存储结构,在其第i个位置插入一个新元素算法的时间复杂度为 。AO(log2n) BO(1)CO(n) DO(n2)【分析】在第i个位置上插入新元素需要从最后一个元素开始后移直到第i个元素后移为止,后移元素的次数为n-i+1,即时间复杂度为O(n)。【答案】C11线性表(a1,a2,an)以链接方式存储时,访问第i个位置元素的时间复杂性为 。AO(i)BO(1)CO(n) DO(i-1
7、)【分析】线性表以链接方式存储时,访问第i个位置元素从第一个元素开始移动指针到第i个元素,移动指针的次数为n-i+1,即时间复杂度为O(n)。【答案】C12将两个各有n个元素的有序表归并成一个有序表,其最少的比较次数是 。An B2n-1 C2n Dn-1【分析】当一个表的最小元素大于另一个表的最大元素时比较次数为最少,共需n次。【答案】A13非空的循环单链表head的尾结点p满足 。Ap-next=headBp-next=NULLCp=NULLDp=head【分析】非空的循环单链表head的尾结点的后继指针指向链表的头结点。【答案】A14在双循环链表p所指结点之后插入s所指结点的操作是 。A
8、p-next=s; s-prior=p; p-next-prior=s; s-prior=p-next;Bp-next=s; p-next-prior=s; s-prior=p; s-next=p-next;Cs-prior=p; s-next=p-next; p-next=s; p-next-prior=s;Ds-prior=p; s-next=p-next; p-next-prior=s; p-next=s; 【分析】由于要将s所指结点插入到p所指结点之后,p结点为s结点的前驱,s结点为p结点的新后继,而结点p的原后继结点为结点s的后继结点,结点s为结点p的原后继结点的前驱结点s。在选项A
9、、B和C中均是先执行操作p-next=s,就是修改了结点p的后继结点s,然后再执行操作p-next-prior=s,因此,无法使得结点s为结点p的原后继结点的前驱结点,这样的赋值会使s结点为其自身的前驱。应先执行操作p-next-prior=s,再执行操作p-next=s。【答案】D15在一个单链表中,已知q所指结点是p所指结点的前驱结点,若在q结点和p结点之间插入s结点,则执行 。As-next=p-next;p-next=s;Bp-next=s-next;s-next=p;Cq-next=s; s-next=p;Dp-next=s; s-next=q;【分析】由于是将s所指结点插入到q和p
10、所指结点之间,即使其为q所指结点的后继结点,为p所指结点的前驱结点,因此s-next的取值应为p,p-next的取值无需改动,q-next的取值应改为s,故A、B和D均是错误的。【答案】C二、判断题1线性表的特点是每个元素都有一个前驱和一个后继。【分析】线性表是一种逻辑结构,其数据元素属于相同数据类型,之间的关系是线性关系。线性表中除第一个数据元素和最后一个数据元素外,外每个元素都有一个前驱和一个后继。【答案】错误2顺序存储的线性表可以按序号随机存取。【分析】因为顺序表在内存是用地址连续的空间存储的,设a1的存储地址为Loc(a1),每个数据元素占d个存储地址,则第i个数据元素的地址为:Loc
11、(ai)=Loc(a)+(i-1)d 1in这就是说只要知道顺序表首地址和每个数据元素所占地址单元的个数就可求出第i个数据元素的地址来,这也是顺序表具有按数据元素的序号随机存取的特点。【答案】正确3链表中的头结点仅起到标识的作用。【分析】头结点是附加在第一个元素结点之前的一个结点,当该链表表示一个非空的线性表时,头结点的指针域指向第一个元素结点,为空表时,该指针域为空。其作用是为了运算上的方便。【答案】错误4线性表采用链表存储时,结点和结点内部的存储空间可以是不连续的。【分析】链表是通过一组任意的存储单元来存储线性表中的数据元素的,为建立起数据元素之间的线性关系,对每个数据元素,除了存放数据元
12、素自身的信息之外,还需要存放其后继元素所在的存储单元的地址。链表中结点的存储空间可以是不连续的,但结点内部的存储空间必须是连续的。【答案】错误5在单链表中和在顺序表中插入一个元素其时间复杂度均为O(n),因此说它们的执行时间是相等的。【分析】大O记法表示时间渐近复杂度,是指一个算法中的时间耗费,往往是问题规模n的函数T(n),当n趋向于无穷大时,T(n)的数量级称为算法的时间渐近复杂度。虽然两种存储结构下的插入操作时间复杂度均为O(n),但由于两者的基本操作不同,因此不能说它们的执行时间是相等的。【答案】错误6所谓静态链表就是一直不发生变化的链表。【分析】静态链表是指以数组方式存储链表的数据,
13、数组的每个元素包含有数据域data和指针域next,其存储的是该结点逻辑上的后继结点的相对地址(即在数组中的下标)。其存储空间不发生变化,而其内容可以发生变化。【答案】错误7静态链表与动态链表在元素的插入、删除上类似,不需做元素的移动。【分析】静态链表是指以数组方式存储链表的数据,对链表进行插入和删除运算时,只需改变指针,不需移动数据。【答案】正确8静态链表既有顺序存储的优点,又有动态链表的优点。所以,它存取表中第i个元素的时间与i无关。【分析】因为静态链表的存取特性与动态链表是一样的,只能顺序地找到第i个元素,不能随机地存取第i个元素,故其存取表中第i个元素的时间与i有关。【答案】错误9静态
14、链表中能容纳的元素个数的最大数在表定义时就确定了,以后不能增加。【分析】因为静态链表是以数组方式存储链表的数据,数组空间大小在数组定义时就已确定,一般不会发生变化。【答案】正确10取线性表的第i个元素的时间同i的大小有关。【分析】存取线性表中数据元素的时间开销与其存储结构有关。顺序存储结构具有按序号随机访问的特点,同i的大小无关。【答案】错误三、简答题1如图2-11所示的双向链表中,欲在结点p前插入一个结点s,请完成有关操作。图2-11 第1题图s-prior=p-prior;p-prior=s; s-next=p;【解答】只能是“s-prior-next=s;”而不能为“p-prior-ne
15、xt=s;”。因为在上面的第二条语句中已经改变了结点p的前驱结点,结点p的前驱结点已经为s结点,而不是操作前的前驱结点。在下面的语句顺序下,可有两个答案进行选择。s-prior=p-prior; p-prior=s;s-next=p;读者做这种题时,最好予以图示,不易出错。2已知线性表非递减有序,存储于一个一维数组A0.n-1 中(表长为n,设为全局量),下面算法的功能是什么?void del(DataType A) int i,j; i=1; while (i=n-1)if (Ai!=Ai+1)i+;elsefor (j=(i+2);jnext) q=L; L=L-next; p=L; wh
16、ile (p-next) p=p-next; p-next=Q; q-next=NULL; return L; 【解答】算法的功能是把单链表的第一个结点从表头移到了链尾。返回的L指向原链表的第二个结点。若原链表表示的线性表是(a1,a2,an),则操作后表示的线性表为(a2,a3, an,a1)。4试描述头指针、头结点、开始结点的区别,并说明头指针和头结点的作用。【解答】头指针是一个指针变量,里面存放的是链表中首结点的地址,并以此来标识一个链表。如链表H,链表L等,表示链表中第一个结点的地址存放在H和L中。头结点是附加在第一个元素结点之前的一个结点,头指针指向头结点。当该链表表示一个非空的线性
17、表时,头结点的指针域指向第一个元素结点,为空表时,该指针域为空。开始结点指第一个元素结点。头指针的作用是用来唯一标识一个单链表。头结点的作用有两个:一是使得对空表和非空表的处理得以统一。二是使得在链表的第一个位置上的操作和在其他位置上的操作一致,无需特殊处理。5在单链表、双链表和单循环链表中,若仅知道指针p指向某结点,而不知道头指针,能否将结点p从相应的链表中删除?若可以,其时间复杂度各为多少?【解答】单链表:若结点p有后继结点,则可将结点p的后继元素数据放入结点p中,再将后继结点删除。时间复杂度为O(1);若结点p无后继结点,则不可以实现。双链表:可以实现,时间复杂度为O(1)。单循环链表:
18、像单链表那样进行操作,也可以从p开始,找结点p的直接前驱,然后再删除p结点,时间复杂度为O(n)。四、算法设计题1设线性表存放在一维数组Aarrsize的前num个分量中,且递增有序。试写一算法,将x插入到线性表的适当位置上,以保持线性表的有序性。并且分析算法的时间复杂度。【分析】直接用题目中所给定的数据结构(顺序存储的思想是用物理上的相邻表示逻辑上的相邻,不一定要将一维数组和表示线性表长度的变量封装成一个结构体),因为是顺序存储,分配的存储空间是固定大小的,所以首先确定是否还有存储空间,若有,则根据原线性表中元素的有序性确定插入元素的插入位置,后面的元素为它让出位置(也可以从高下标端开始一边
19、比较,一边移位),然后插入x,最后修改表示表长的变量。【算法】InsertSeq(DataType A,int *num,DataType x) /设num为表的最大下标 int i; if (*num=arrsize-1) return 0; else i=*num; while (i=0&Aix) /边找位置边移动 Ai+1=Ai; i-; Ai+1=x; /找到的位置是插入位的下一位 (*num)+; return 1; 时间复杂度为O(n)。2假设在长度大于1的单循环链表中,既无头结点也无头指针。s为指向链表中某个结点的指针,试编写算法删除结点s的直接前驱结点。【分析】利用循环单链表的
20、特点,通过s指针可循环找到其前驱结点p及p的前驱结点q,然后可删除结点p。【算法】viod delepre(LNode *s) LNode *p,*q; p=s; while (p-next=s) q=p; p=p-next; q-next=s; delete p;3已知两个单链表A与B分别表示两个集合,其元素递增排列,编写一个函数求出A和B的交集C,要求C同样以元素值递增的单链表形式存储。【分析】交集指的是两个单链表的元素值相同的结点的集合,为了操作方便,先让单链表C带有一个头结点,最后将其删除掉。算法中指针p用来指向A中的当前结点,指针q用来指向B中的当前结点,将其值进行比较,两者相等时,
21、属于交集中的一个元素,两者不等时,将其较小者跳过,继续后面的比较。【算法】LinkNode *inter(LinkList A,B) LNode *q,*p,*r,*s,*C; C=new LNode; r=C; p=A; q=B; while (p & q ) if (p-datadata) p=p-next; else if (p-data=q-data) s=new LNode; s-data=p-data; r-next=s; r=s; p=p-next; q=q-next; else q=q-next; r-next=NULL; r=C-next; delete C; return r;4单链表L是一个递减有序表,试编写一个高效算法,删除表中值大于min且小于max的结点(若表中有这样的结点),同时释放被删结点的空间,这里min 和max 是两个给定的参数。并分析算法的时间复杂度。【分析】由于单链表L是一个递减有序表,即由大到小有序,故可从表头开始查找第一个比max小的结点,记住其位置,再接着向后查找第一个不大于min的结点,然后将它们之间的结点删除。【算法】LinkList delete(LinkList L,int min,int max) /设L为带头结点的循环链表 LNode *p,*q,*s,*k; if(L-next) p=L-next; s=L; wh
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年有关陶瓷实习报告4
- 电锯锌钢管项目可行性研究报告
- 中国汽车专用挡泥板项目投资可行性研究报告
- 中国电动船市场供需现状及投资战略研究报告
- 2025年不锈钢精铸件项目可行性研究报告
- 2025年中国骨科医疗器械行业发展趋势预测及投资战略咨询报告
- 2025年中国抗痤疮制剂行业发展概况及行业投资潜力预测报告
- 2025年中国临床检验分析仪器行业市场深度分析及投资潜力预测报告
- 二甲基一氯硅烷行业深度研究报告
- 2025关于解除租房合同协议书及赔偿问题
- 期末核心素养测评卷2023-2024学年语文五年级上册+统编版
- 医疗器械质量安全风险会商管理制度
- 《我爱上班》朗诵稿
- 2024年石油石化技能考试-石油钻井工笔试参考题库含答案
- 2024年度带状疱疹课件
- 电桩采购安装充电桩调试验收方案
- 消防设施安全检查表
- 钻孔灌注桩施工方案 (详细)
- 新建南通至宁波高速铁路站前Ⅲ标二分部出海栈桥及综合码头(自用)工程海域使用论证报告表
- 车身稳定系统课件
- 2023-2024学年广东省东莞市七年级上期末数学试卷附答案
评论
0/150
提交评论