完整版数据结构复习题附答案.docx
- 文档编号:1577493
- 上传时间:2022-10-23
- 格式:DOCX
- 页数:40
- 大小:317.09KB
完整版数据结构复习题附答案.docx
《完整版数据结构复习题附答案.docx》由会员分享,可在线阅读,更多相关《完整版数据结构复习题附答案.docx(40页珍藏版)》请在冰豆网上搜索。
完整版数据结构复习题附答案
一、算法设计题(每题15分,共60分)
答题要求:
1用自然语言说明所采用算法的思想;
2给出每个算法所需的数据结构定义,并做必要说明;
3写出对应的算法程序,并做必要的注释。
1、有一个带头结点的单链表,每个结点包括两个域,一个是整型域info,另一个是指向下
一个结点的指针域next。
假设单链表已建立,设计算法删除单链表中所有重复出现的结点,使得info域相等的结点只保留一个。
3、约瑟夫环问题(Josephus问题)是指编号为1、2、…,n的n(n>0)个人按顺时针方向围坐成一圈,现从第s个人开始按顺时针方向报数,数到第m个人出列,然后从出列的下
一个人重新开始报数,数到第m的人又出列,…,如此重复直到所有的人全部出列为止。
现要求采用循环链表结构设计一个算法,模拟此过程。
4、编程实现单链表的就地逆置。
23.在数组A[1..n]中有n个数据,试建立一个带有头结点的循环链表,头指针为h,要求
链中数据从小到大排列,重复的数据在链中只保存一个
5、设计一个尽可能的高效算法输出单链表的倒数第K个元素。
3、假设以I和0分别表示入栈和出栈操作。
栈的初态和终态均为空,入栈和出栈的操作序
列可表示为仅由I和O组成的序列,称可以操作的序列为合法序列,否则称为非法序列。
(15
分)
(1)下面所示的序列中哪些是合法的?
A.IOIIOIOOB.IOOIOIIOC.IIIOIOIOD.IIIOOIOO
(2)通过对
(1)的分析,写出一个算法,判定所给的操作序列是否合法。
若合法,返回
true,否则返回false(假定被判定的操作序列已存入一维数组中)。
5、设从键盘输入一整数的序列:
a1,a2,a3,…,an,试编写算法实现:
用栈结构存储输入的整数,当ai工-1时,将ai进栈;当ai=-1时,输出栈顶整数并出栈。
算法应对异常情况(入栈满等)给出相应的信息。
设有一个背包可以放入的物品重量为S,现有n件物品,重量分别为W,W,...,W。
问能否从这n件物品中选择若干件放入背包,使得放入的重量之和正好是S。
设布尔函数Knap(S,n)表示背包问题的解,W(i=1,2,...,n)均为正整数,并已顺序存储地在数组W中。
请在下列算法的下划线处填空,使其正确求解背包问题。
Knap(S,n)
若S=0
则Knap—true
否则若(S<0)或(S>0且n<1)
则Knap—false
否则若Knap
(1),=true
则print(W[n]);Knap—true
否则Knap—Knap
(2),
设有一个顺序栈S,元素s1,s2,s3,s4,s5,s6依次进栈,如果6个元素的出栈顺序为s2,s3,s4,
s6,s5,si,则顺序栈的容量至少应为多少?
画出具体进栈、出栈过程。
假定采用带头结点的单链表保存单词,当两个单词有相同的后缀时,则可共享相同的后缀存
储空间。
例如:
词共同后缀的起始位置,分析算法时间复杂度。
将n(n>1)个整数存放到一维数组R中。
设计一个尽可能高效(时间、空间)的算
法,将R中保存的序列循环左移p(0
变换为(Xp,xp+i,…,Xn-1,X0,Xi,…,Xp-i)。
4.编写一个过程,对一个nxn矩阵,通过行变换,使其每行元素的平均值按递增顺序排列。
7.给定一个整数数组b[O..N-i],b中连续的相等元素构成的子序列称为平台。
试设计算法,
求出b中最长平台的长度。
【
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 完整版 数据结构 复习题 答案