第2章-线性表习题及参考答案

上传人:F****n 文档编号:99550751 上传时间:2019-09-19 格式:DOC 页数:8 大小:43KB
返回 下载 相关 举报
第2章-线性表习题及参考答案_第1页
第1页 / 共8页
第2章-线性表习题及参考答案_第2页
第2页 / 共8页
第2章-线性表习题及参考答案_第3页
第3页 / 共8页
第2章-线性表习题及参考答案_第4页
第4页 / 共8页
第2章-线性表习题及参考答案_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《第2章-线性表习题及参考答案》由会员分享,可在线阅读,更多相关《第2章-线性表习题及参考答案(8页珍藏版)》请在金锄头文库上搜索。

1、第二章 线性表习题一 判断题1线性表的逻辑顺序与存储顺序总是一致的。2顺序存储的线性表可以按序号随机存取。3顺序表的插入和删除操作不需要付出很大的时间代价,因为每次操作平均只有近一半的元素需要移动。 4线性表中的元素可以是各种各样的,但同一线性表中的数据元素具有相同的特性,因此是属于同一数据对象。5在线性表的顺序存储结构中,逻辑上相邻的两个元素在物理位置上并不一定紧邻。6在线性表的链式存储结构中,逻辑上相邻的元素在物理位置上不一定相邻。7线性表的链式存储结构优于顺序存储结构。8在线性表的顺序存储结构中,插入和删除时,移动元素的个数与该元素的位置有关。9线性表的链式存储结构是用一组任意的存储单元

2、来存储线性表中数据元素的。10在单链表中,要取得某个元素,只要知道该元素的指针即可,因此,单链表是随机存取的存储结构。二 单选题 (请从下列A,B,C,D选项中选择一项)1线性表是( ) 。(A) 一个有限序列,可以为空; (B) 一个有限序列,不能为空; (C) 一个无限序列,可以为空; (D) 一个无序序列,不能为空。 2对顺序存储的线性表,设其长度为n,在任何位置上插入或删除操作都是等概率的。插入一个元素时平均要移动表中的( )个元素。 (A) n/2 (B) n+1/2 (C) n -1/2 (D) n 3线性表采用链式存储时,其地址( ) 。(A) 必须是连续的; (B) 部分地址必

3、须是连续的; (C) 一定是不连续的; (D) 连续与否均可以。 4用链表表示线性表的优点是 ( )。(A)便于随机存取 (B)花费的存储空间较顺序存储少(C)便于插入和删除 (D)数据元素的物理顺序与逻辑顺序相同5 某链表中最常用的操作是在最后一个元素之后插入一个元素和删除最后一个元素,则采用( )存储方式最节省运算时间。(A)单链表 (B)双链表 (C)单循环链表 (D)带头结点的双循环链表6 循环链表的主要优点是( ) 。(A)不再需要头指针了(B)已知某个结点的位置后,能够容易找到他的直接前趋(C)在进行插入、删除运算时,能更好的保证链表不断开(D)从表中的任意结点出发都能扫描到整个链

4、表7 下面关于线性表的叙述错误的是( )。(A) 线性表采用顺序存储,必须占用一片地址连续的单元;(B) 线性表采用顺序存储,便于进行插入和删除操作;(C) 线性表采用链式存储,不必占用一片地址连续的单元;(D) 线性表采用链式存储,不便于进行插入和删除操作;8 单链表中,增加一个头结点的目的是为了()。(A) 使单链表至少有一个结点 (B)标识表结点中首结点的位置(C)方便运算的实现 (D) 说明单链表是线性表的链式存储9 若某线性表中最常用的操作是在最后一个元素之后插入一个元素和删除第一个元素,则采用( )存储方式最节省运算时间。(A) 单链表 (B) 仅有头指针的单循环链表 (C) 双链

5、表 (D) 仅有尾指针的单循环链表10 若某线性表中最常用的操作是取第i个元素和找第i个元素的前趋元素,则采用( )存储方式最节省运算时间( )。(A) 单链表 (B) 顺序表 (C) 双链表 (D) 单循环链表三 填空题1带头结点的单链表H为空的条件是_。1 非空单循环链表L中*p是尾结点的条件是_。3在一个单链表中p所指结点之后插入一个由指针s所指结点,应执行s-next=_;和p-next=_的操作。4在一个单链表中p所指结点之前插入一个由指针s所指结点,可执行以下操作:s-next=_;p-next=s;t=p-data;p-data=_;s-data=_;5在顺序表中做插入操作时首先

6、检查_。四 算法设计题1 设线性表存放在向量Aarrsize的前elenum个分量中,且递增有序。试写一算法,将x 插入到线性表的适当位置上,以保持线性表的有序性。并且分析算法的时间复杂度。2 已知一顺序表A,其元素值非递减有序排列,编写一个函数删除顺序表中多余的值相同的元素。3 线性表用顺序存储,设计一个算法,用尽可能少的辅助存储空间将顺序表中前m个元素和后n个元素进行整体互换。即将线性表(a1, a2, , am, b1, b2, , bn) 改变为:(b1, b2, , bn , a1, a2, , am)。4 已知带头结点的单链表L中的结点是按整数值递增排列的,试写一算法,将值为x 的

7、结点插入到表L中,使得L仍然有序。并且分析算法的时间复杂度。5 假设长度大于1的循环单链表中,既无头结点也无头指针,p为指向该链表中某一结点的指针,编写一个函数删除该结点的前趋结点。五 上机实习题目1 Josephu 问题Josephu 问题为:设编号为1,2, n的n个人围坐一圈,约定编号为k(1=k0)个人按顺时针方向围坐一圈,每个人持有一个正整数密码。开始时任选一个正整数做为报数上限m,从第一个人开始顺时针方向自1起顺序报数,报到m是停止报数,报m的人出列,将他的密码作为新的m值,从他的下一个人开始重新从1报数。如此下去,直到所有人全部出列为止。令n最大值取30。要求设计一个程序模拟此过

8、程,求出出列编号序列。源程序代码:(在Tubro C 2.0测试通过)#include #include struct node int number; /* 人的序号 */ int cipher; /* 密码 */ struct node *next; /* 指向下一个节点的指针 */;struct node *CreatList(int num) /* 建立循环链表 */ int i; struct node *ptr1,*head; if(ptr1=(struct node *)malloc(sizeof(struct node)=NULL) perror(malloc); return

9、 ptr1; head=ptr1; ptr1-next=head; for(i=1;inext=(struct node *)malloc(sizeof(struct node)=NULL) perror(malloc); ptr1-next=head; return head; ptr1=ptr1-next; ptr1-next=head; return head;main() int i,n=30,m; /* 人数n为30个 */ struct node *head,*ptr; randomize(); head=CreatList(n); for(i=1;inumber=i; head-

10、cipher=rand(); head=head-next; m=rand(); /* m取随机数 */ i=0; /* 因为我没办法删除head指向的节点,只会删除head的下一节点,所以只能从0数起。*/ while(head-next!=head) /* 当剩下最后一个人时,退出循环 */ if(i=m) ptr=head-next; /* ptr记录数到m的那个人的位置 */ printf(number:%dn,ptr-number); printf(cipher:%dn,ptr-cipher); m=ptr-cipher; /* 让m等于数到m的人的密码 */ head-next=ptr-next; /* 让ptr从链表中脱节,将前后两个节点连接起来 */ head=hea/d-next; /* head移向后一个节点 */ free(ptr); /* 释放ptr指向的内存 */ i=0; /* 将i重新置为0,从0再开始数 */ else head=head-next; i+; printf(number:%dn,head-number); printf(cipher:%dn,head-cipher); free(head); /* 让最后一个人也出列 */ 第二章 线性表习题(参考答案)一 判断题12345678910二 单选题123

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 教学/培训

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号