第章线性表习题参考答案.docx

上传人:Che****ry 文档编号:17157637 上传时间:2022-05-21 格式:DOCX 页数:7 大小:37.67KB
返回 下载 相关 举报
第章线性表习题参考答案.docx_第1页
第1页 / 共7页
第章线性表习题参考答案.docx_第2页
第2页 / 共7页
点击查看更多>>
资源描述

《第章线性表习题参考答案.docx》由会员分享,可在线阅读,更多相关《第章线性表习题参考答案.docx(7页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精品名师归纳总结资料word 精心总结归纳 - - - - - - - - - - - -习题二参考答案一、挑选题1. 链式储备结构的最大优点是(D)。A. 便于随机存取B. 储备密度高C. 无需预安排空间D. 便于进行插入和删除操作2. 假设在次序表a 0,a 1,a n 1 中,每一个数据元素所占的储备单元的数目为4,且第 0 个数据元素的储备的址为 100,就第 7 个数据元素的储备的址是(D ) 。A.106B. 107C.124D.1283. 在线性表中如常常要存取第i 个数据元素及其前趋,就宜采纳(A)储备方式。A. 次序表B.带头结点的单链表C. 不带头结点的单链表D.循环单链表

2、4. 在链表中如常常要删除表中最终一个结点或在最终一个结点之后插入一个新结点,就宜采纳(C)储备方式。A.次序表B.用头指针标识的循环单链表C.用尾指针标识的循环单链表D.双向链表5. 在一个单链表中的p 和 q 两个结点之间插入一个新结点,假设新结点为S, 就修改链的java语句序列是( D )。A. s.setNextp; q.setNexts;B. p.setNexts.getNext; s.setNextp;C. q.setNexts.getNext; s.setNextp;D. p.setNexts; s.setNextq;6. 在一个含有n 个结点的有序单链表中插入一个新结点,使单

3、链表仍旧保持有序的算法的时间复杂度是( C ) 。A. O 1B.O log 2nC.O nD.O n27. 要将一个次序表a 0,a 1,a n-1 中第 i 个数据元素ai 0 i n-1 删除,需要移动(B)个数据元素。A. iB. n-i-1C. n-iD. n-i+18. 在带头结点的双向循环链表中的p 结点之后插入一个新结点s ,其修改链的java语句序列是(D)。A. p.setNexts; s.setPriorp; p.getNext.setPriors; s.setNextp.getPrior;B. p.setNexts; p.getNext.setPriors; s.set

4、Priorp; s.setNextp.getNext;C. s.setPriorp; s.setNextp.getNext; p.setNexts; p.getNext.setPriors;D. s.setNextp.getNext; s.setPriorp; p.getNext.setPriors;p.setNexts;9. 次序表的储备密度是(B),而单链表的储备密度是(A)。A小于 1B.等于 1C.大于 1D.不能确定10. 对于图 2.29 所示的单链表,以下表达式值为真 的是( D)。可编辑资料 - - - 欢迎下载精品名师归纳总结headABCDE可编辑资料 - - - 欢迎下载

5、精品名师归纳总结P1P2图 2.29单链表 head 的储备结构图A. head.getNext.getData=CB. head.getData=BC.P1.getData=DD. P 2.getNext=null二、填空题1. 线性表是由n( n 0)个数据元素所构成的有限序列,其中n 为数据元素的个数,称为线性表的长度,可编辑资料 - - - 欢迎下载精品名师归纳总结学习资料 名师精选 - - - - - - - - - -第 1 页,共 5 页 - - - - - - - - - -可编辑资料 - - - 欢迎下载精品名师归纳总结资料word 精心总结归纳 - - - - - - -

6、- - - - -n=0 的线性表称为空表。2. 线性表中有且仅有一个开头结点和终端结点,除开头结点和终端结点之外,其它每一个数据元素有且仅有一个 前驱,有且仅有一个后继。3. 线性表通常采纳次序储备和 链式储备两种储备结构。 如线性表的长度确定或变化不大,就适合采纳次序储备储备结构进行储备。4. 在次序表 a 0,a 1,a n-1 中的第i 0 i n-1 个位置之前插入一个新的数据元素,会引起n-i个数据元素的移动操作。5. 在线性表的单链表储备结构中,每一个结点有两个域,一个是数据域, 用于储备数据元素值本身,另一个是指针域,用于储备后继结点的的址。6. 在线性表的次序储备结构中可实现

7、快速的随机存取,而在链式储备结构中就只能进行次序存取。7. 次序表中规律上相邻的数据元素,其物理位置肯定相邻,而在单链表中规律上相邻的数据元素,其物理位置 不肯定相邻。8. 在仅设置了尾指针的循环链表中,拜访第一个结点的时间复杂度是O(1) 。9. 在含有n 个结点的单链表中,如要删除一个指定的结点p,就第一必需找到指定结点p 的前驱,其时间复杂度为 O( n) 。10. 如将单链表中的最终一个结点的指针域值改为单链表中头结点的的址值,就这个链表就构成了循环单链表 。三、算法设计题1. 编写一个次序表类的成员函数,实现对次序表就的逆置的操作。所谓逆置,就是把(a1,a 2,a n)变成( an

8、,a n-1 ,a 1)。所谓就的,就是指逆置后的数据元素仍储备在原先次序表的储备空间中,即不为逆置后的次序表另外安排储备空间。参考答案 :public void reverse for int i = 0,j=curLen-1; i j; i+,j- Object temp = listElemi; listElemi = listElemj; listElemj = temp;2. 编写一个次序表类的成员函数,实现对次序表循环右移k 位的操作。 即原先次序表为(a1,a 2,a n-k ,a n-k+1 , an),循环向右移动k 位后变成( an-k+1 , a n ,a 1,a 2,a

9、 n-k )。要求时间复杂度为O( n)。参考答案 :public void shitint k int n=curLen,p=0,i,j,l; Object temp;fori=1;i=k;i+ifn%i=0&k%i=0 /求n和k的最大公约数p p=i;fori=0;ilistElem6, listElem6-listElem12, listElem12- listElem3, listElem3- listElem9, listElem9- listElem0.其次条链 : listElem1-listElem7, listElem7-listElem13, listElem13- li

10、stElem4,listElem4-listElem10, listElem10- listElem1.第三条链 : listElem2- listElem8, listElem8- listElem14, listElem14-listElem5, listElem5-listElem11, listElem11-listElem2.恰好使全部元素都右移一次.虽然未经数学证明, 但信任上述规律应当是正确的.3. 编写一个单链表类的成员函数,实现在非递减的有序单链表中插入一个值为x 的数据元素,并使单链表仍保持有序的操作。参考答案 方法一 :public void insertint x No

11、de p = head.getNext;/p指向首结点 Node q = head;/ q用来记录p 的前驱结点 int temp;while p .= null temp = Integer p.getData.intValue; if temp x q = p;p = p.getNext; elsebreak;Node s = new Nodex; /生成新结点s.setNextp;/将 s 结点插入到单链表的q 结点与 p 结点之间q.setNexts;参考答案 方法二 :public void insertint x Node p = head.getNext; /p指向首结点whil

12、e p.getNext.= null&Integer p.getNext.getData.intValuex p = p.getNext;Node s = new Nodex; /生成新结点s.setNextp.getNext;/将 s 结点插入到单链表的q 结点与 p 结点之间p.setNexts;可编辑资料 - - - 欢迎下载精品名师归纳总结4. 编写一个单链表类的成员函数,实现对带头结点的单链表就的逆置的操作。所谓逆置,就是把(a1,a 2,a n)变成( an,a n-1 ,a 1)。所谓就的,就是指逆置后的结点仍储备在原先单链表的储备空间中,只不过通过修改链来转变单链表中每一个结点

13、之间的规律位置关系。参考答案 :public void reverse /实现对单链表就的逆置 采纳的是头插法Node p = head.getNext; head.setNextnull;Node q;while p .= null q = p.getNext; p.setNexthead.getNext; head.setNextp;p = q;5. 编写一个单链表类的成员函数,实现删除不带头结点的单链表中数据域值等于x 的第一个结点的操作。如删除胜利,就返回被删除结点的位置。否就,返回-1 。参考答案 :public int removeObject x Node p = head;/初

14、始化 ,p 指向首结点Node q=null; /q用来记录p 的前驱结点int j = 0;/j为计数器/从单链表中的首结点元素开头查找,直到p.getData指向元素 x 或到达单链表的表尾while p .= null & .p.getData.equalsx q=p;p = p.getNext;/指向下一个元素+j;/计数器的值增1if p.=null&q=null /删除的是单链表中的首结点head=p.getNext;else if p .= null /删除的是单链表中的非首结点q.setNextp.getNext;可编辑资料 - - - 欢迎下载精品名师归纳总结elseretu

15、rn -1;/值为 x 的结点在单链表中不存在可编辑资料 - - - 欢迎下载精品名师归纳总结return j;6. 编写一个单链表类的成员函数,实现删除带头结点的单链表中数据域值等于x 的全部结点的操作。要求函数返回被删除结点的个数。参考答案 :public int removeAllObject x Node p = head.getNext;/初始化 ,p 指向首结点 ,j为计数器Node q = head; /用来记录p 的前驱结点int j = 0;/用来记录被删除结点的个数while p .= null /从单链表中的首结点开头对整个链表遍历一次可编辑资料 - - - 欢迎下载精品

16、名师归纳总结if p.getData.equalsx q.setNextp.getNext;+j;/计数器的值增1 elseq = p;p = p.getNext;/指向下一个元素return j;/返回被删除结点的个数7. 编写一个多项式类的成员函数,实现将一个用循环链表表示的稀疏多项式分解成两个多项式的操作,并使两个多项式中各自仅含奇次项或偶次项。要求利用原先循环链表中的储备空间构成这两个链表。参考答案 :public CircleLinkList separatePolynCircleLinkList cList CircleLinkList cList1 = new CircleLin

17、kList;/含奇次项的多项式 Node p1 = cList1.getHead;/ p2指向奇次项多项式的头结点 CircleLinkList cList2 = new CircleLinkList;/含偶次项的多项式 Node p2 = cList2.getHead;/ p2指向偶次项多项式的头结点Node p = cList.getHead.getNext;/原多项式的首结点while p.=cList.getHead PolynNode data = PolynNode p.getData; int expn = data.getExpn;if expn % 2 .= 0 /加入奇次项多项式p1.setNextp; p1 = p; else /加入偶此项多项式p2.setNextp; p2 = p;p = p.getNext;p1.setNextcList1.getHead; p2.setNextcList2.getHead; CircleLinkList polyns = cList1, cList2 ; return polyns;可编辑资料 - - - 欢迎下载

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

当前位置:首页 > 教育专区 > 高考资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁