1、带答案更新的数据结构复习题复习题第一章第五章一、 单选或填空题1. 下列程序段中S语句的执行频度为 。for(i0;in;i+ )for(j0;ji;j+ ) S;2. 下列算法的时间复杂度是( )。for(i0;in;i+ ) cii;3. 算法的时间复杂度可表示为 O(1)、线性阶 、平方阶O(n2)、对数阶O(logn)和指数阶O(2n)等。4 以下关于数据结构的基本概念中,叙述正确的是 A) 数据元素是数据不可分割的最小单位。B) 数据是数据对象的子集。C) 数据元素之间的关系在计算机中可用顺序映像和非顺序映像两种不同的方法表示。D) 数据结构在计算机中的表示又称为逻辑结构。5. 在数
2、据结构中,数据的逻辑结构包括( )。 A) 线性结构和非线性结构 B) 逻辑结构和物理结构 C) 顺序结构和链式结构 D) 虚拟结构和抽象结构 6. 在数据结构中,数据的存储结构包括 。 A) 线性结构和非线性结构 B) 逻辑结构和物理结构 C) 顺序结构和链式结构 D) 虚拟结构和抽象结构 7. 线性结构的数据元素之间存在一种( )。A一对多关系 B多对多关系C多对一关系 D一对一关系8. 在长度为n的顺序表中插入一个元素,需要平均移动 个元素。A) n/2 B)nC) n(n-1) D) n(n+1)9. 在有n个元素的顺序表中做插入、删除运算,平均时间复杂度为 。10. 顺序表中逻辑上相
3、邻的元素物理位置 相邻,单链表中逻辑上相邻的元素的物理位置 相邻。A)必然、必然 B)必然、不一定C)不一定、必然 D)不一定、不一定11相对于顺序存储而言,链式存储的优点是( )。A随机存取 B节约空间C增、删操作方便 D节点间关系简单12 以下关于头结点的描述中,叙述错误的是 A) 头结点是对链表首元结点的别称B) 若链表中附设头结点,则头指针一定不为空C) 头结点中不存储链表的数据元素,而是一些诸如表长之类的辅助信息D) 在单链表中附设头结点,插入或删除首元素时不必进行特殊处理13已知L是无表头结点的单链表,且P所指结点既不是首元结点,也不是尾元结点,则在P之后插入S所指结点,则执行(
4、)。A) S-next=P-next; P-next=S;B) P-next=S-next; S-next=P;C) S-next=P; P-nextS;D) P-next=S; S-next=P;14. 已知L是带表头结点的非空单链表,且P结点是S结点的直接前驱。则删除S结点的语句序列为 。I. P-next = S ;free(P)II. P-next = P-next-next; free(S)III. P-next = S-next; free(S) IV. P = P-next ;free(S)A) I和II正确 B) II和 III正确C) III和IV正确 D) 全部正确15.
5、已知L是带表头结点的单链表,则删除首元结点的语句序列是( )。A) L-next =L-next-next; free(L)B) P = L ;L= P-next ;free(P)C) P = L-next ; L-next= P-next ;free(P)D) P = L ;L= P-next ;free(P)16. 已知L是一带有头结点的单链表的头指针,则该单链表为空的条件是 。17. 已知P结点是某双向链表的中间结点,则删除P结点的语句序列是 , ,free(P);18. 设将整数1,2,3,4,5依次进栈,最后都出栈,出栈可以在任何时刻(只要栈不空)进行,则出栈序列不可能的是( )。A
6、) 32415 B) 45231 C) 32145 D) 4532119. 在栈中由顶向下已存放元素c, b, a 在第4个元素d入栈前,栈中元素可以出栈,则不可能的出栈序列是 A) dcba B) cbda C) cdba D) cadb20. 若元素a,b,c,d,e,f依次进栈,允许进栈、退栈操作交替进行,但不允许连续3次进行退栈操作,则不可能得到的出栈序列是( )。Adcebfa Bcbdaef Cbdcaef Dafedcb21. 设有栈S和队列Q,其初始状态为空,元素a1,a2,a3,a4,a5,a6依次入栈,出栈的元素进入队列Q。若元素出队列的顺序是a2,a4,a3,a6,a5,
7、a1,则栈的容量至少是 。22. 某队列允许在其两端进行入队操作,但仅允许在一端进行出队操作,则abcde顺序入队,不可能的到的顺序是( )。Abacde Bdbace Cdbcae Decbad23. 设用一维数组An存储一个栈,令An为栈底,用整型变量T指示当前栈顶位置,AT为栈顶元素。当从栈中弹出一个元素时,变量T的变化为( )。A) T=T+1 B) T=T-1 C) T不变 D) T=n-124. 循环队列是满队列的条件是 。A)Q.rearQ.front B)(Q.rear+1) % maxsizeQ.frontC)Q.rear0 D)Q.front025. 在具有m个单元的顺序存
8、储的循环队列中,假定front和rear分别为队首指针和队尾指针,则判断队满的条件是( )A. front= (rear1) % m B. front1= rearC. front= rear D. rear= m26. 在具有n个单元的顺序存储的循环队列中,假定front和rear分别为队首指针和队尾指针,则判断队空的条件是( )A)front= (rear1) % n B)front1=rearC)front=rear D)front=027. 循环队列用数组A0m-1存放其数据元素。设front指向其实际的队头,rear指向其实际队尾的下一个位置,则当前队列中的数据元素有 个。28 在串
9、的运算中,StrLength(Concat (aa,bb)的返回值为 A) 0B) 8C) 6D) 429设s1”I have_”,s2”a dream”,则strcat(s1, s2)的值是 I have_ a dream ,SubString(s1,4,3)的值是 ave 。30. 设s1”I am a student”,s2”a student”,则Index(s1,s2)的值是 。31. 假设有二维数组A56,每个元素用相邻的4个字节存储,存储器按字节编址。已知A的基地址为1000,则数组A的最后一个元素a45的第一个字节的地址是 ;按行存储时,元素a14的第一个字节的地址是 。32.
10、 已知二维数组A1.7,1.7按列存放,其起始存储位置为100,每个元素占用4个字节,则元素A4,6的第一个字节的地址为 。A)204 B)252 C)208 D)25633. 一个非空广义表的表头( )。A一定是子表 B一定是原子 C不能是子表 D可以是原子,也可以是子表34. 设广义表L((a,b),c,()),则head(L) ,tail(L) 。第六章一、 单选或填空题1. 已知完全二叉树的第7层上有10个叶子结点,则整个二叉树的结点数最多是 A) 73 B) 63 C) 235 D) 2452. 300个结点的完全二叉树的叶结点有 个。3一个具有1025个结点的二叉树的高h为_。A)
11、11 B)10 C)11至1025之间 D)10至1024之间4. m叉树的第i层至多有 个结点5. 将一棵有100个节点的完全二叉树从上到下,从左到右依次对节点进行编号,根节点的编号为1,则编号为49的节点的右孩子编号为( )。A99 B98 C50 D486把如右图所示的树转换成二叉树时,C是( ) A. A的左子女 B. A的右子女 C. B的左子女 D. B的右子女7. 设森林F中有3棵树,其结点个数分别是n1、n2和n3,则与森林对应的二叉树根结点的右子树上的结点个数是 。 A) n1-1 B)n1+n2 C) 0 D) n2+n38.在一颗度为4的树T中,若有20个度为4的结点,1
12、0个度为3的结点,5个度为2的结点,10个度为1的结点,则树T的叶结点个数有 个。9. 一棵二叉树中序遍历结果为DCBAEFG,后序遍历结果为DCBGFEA。则此二叉树先序遍历的结果应为 A) ABCDEFG B)ABECFDG C)AEBFCGD D)不能确定10. 将一棵树t 转换为孩子兄弟链表表示的二叉树h,则t 的后根遍历是h 的A)先序遍历 B)中序遍历 C)后序遍历 C)层序遍历11.现有一段电文共100个字符,其中A出现50次,B出现20次,C出现5次,D出现10次,E出现15次。现对这5个字符进行哈夫曼编码,则其平均码长为 。二、 解答题1. 某二叉树层序序列为abcdefgh
13、ij,中序序列为bgdhjaecif。(1)画出该二叉树;(2)画出该二叉树的后序后继线索树;(3)画出该二叉树对应的树或森林。2. 一棵二叉树的先序、中序和后序序列分别如下,其中有部分未给出。 先序:_B_EHI_FG_K 中序:D_HEIA_CJG_ 后序:_H_EBF_KG_A (1)试求出空格处的结点字符; (2)画出该二叉树;(3)画出与该二叉树对应的树或森林。3. 已知某通讯用电文仅有A、B、C、D、E、F六个字符构成,其出现的频率分别为23,5,14,8,25,7,请首先建立哈夫曼树,然后给出六个字符的哈夫曼编码(注:建立哈夫曼树时权值小的为左子树,权值大的为右子树)。第七章一
14、单选或填空题1. 若某有向图的邻接矩阵A只有0和1两种元素,其中aij1表示有向图中存在弧,则编号为i顶点的入度可用 表示。A) 邻接矩阵中第i行元素之和 B) 邻接矩阵中第i列元素之和 C) 邻接矩阵中对角线元素之和 D) 以上均不正确2. 使用邻接表作为某无向图的存储结构,若无向完全图中有n个顶点,则邻接表中必存在 个表结点。A)n2 B)2n C)n(n-1) D) 2n-13. 一个含有n个顶点和e条边的无向图,在其邻接矩阵存储结构中共有()零元素。Ae B2e Cn2-e Dn2-2e4在一个有向图中,所有顶点的入度之和等于所有顶点的出度之和的( )倍。A1/2 B1 C2 D45下
15、列关于图的叙述中,正确的是( )、 回路是简单路径 、存储稀疏图,用邻接矩阵比邻接表更省空间 、若有向图中存在拓扑序列,则该图不存在回路 A仅 B仅、 C仅 D仅、 6. 有n个顶点的无向图至少有 条边才能确保是一个连通图。7在有n个结点的无向图中,其边数最多为 。8. 对于具有n个结点的连通图,它的最小生成树中有 条边。A)n2 B)n-1 C)n(n-1) D) n(n-1)/29. 关键路径是AOE网中A)从源点到汇点的最长路径 B)从源点到汇点的最短路径C)最长回路 D)最短回路 10. 以下关于图的描述中,正确的是A) n个顶点的无向完全图有条边。B) 对任何用顶点表示活动的网络(A
16、OV网)进行拓扑排序的结果是唯一的。C) 若图G的邻接矩阵是对称的,则G一定是无向图D) 有向图的邻接矩阵一定是非对称矩阵11. 对下图进行拓扑排序,可以得到不同的拓扑序列的个数是()A5 B3 C2 D112下图为用边表示活动的AOE-网。则V8的最早发生时间是 。二、解答题1. 已知某无向图的邻接表存储结构如下图所示,求解下列问题:(1)画出它的无向图;(2)画出它的的邻接矩阵存储结构;(3)从顶点A出发,画出其广度优先生成树。2. 已知无向带权图G的邻接矩阵如下所示。(1)从顶点a出发,求其深度优先生成树; (2)从顶点a出发,根据普里姆算法构造最小生成树,过程在下面的图(1)至(5)中
17、画出。(3)给出邻接表存储结构;3. 对于如下图所示的带权有向图,求解关键路径, 计算各事件(顶点)的最早发生时间和最迟发生时间,各活动(弧)的最早开始时间和最迟开始时间。请填写在答题纸的表格中。表1 计算各事件(顶点)的最早发生时间和最迟发生时间,请填写在表1的空白处。顶点abcdefghkve06457151418vl0810161418表2 计算各活动(弧)的最早开始时间和最迟开始时间,请填写在表2的空白处。弧abacadbecedfegehfhgkhke00064571514l38101614 4.对于右图,求解下列问题:(1)写出该图的邻接矩阵;(2)写出全部拓扑排序序列;(3)从顶
18、点V1出发,给出深度优先遍历生成树;(4)按照迪杰斯特拉算法,求V1结点到各点的最短路径,填写表1的空白处。终点从V1到各终点的距离和最短路径的求解过程i=1i=2i=3i=4i=5i=6i=7V22-V333-V4-V51313-V6-V7-V8161616vjv2v3第九章一单选或填空题1已知一个长度为11的有序表,使用折半查找的方法,查找第8个元素时所需进行的关键字比较次数为 。2. 已知一个长度为16的有序表,使用折半查找的方法,查找一个不存在的元素,则所需进行的关键字比较次数最多是 。A4 B5 C6 D73. 在二叉排序树中,关键字值最大的结点A)左指针一定为空 B)右指针一定为空
19、C)左右指针均为空 D)左右指针均不为空4 对于下列关键字序列,不可能构成某二叉排序树中一条查找路径的序列是( ) A95,22,91,24,94,71 B92,20,91,34,88,35 C21,89,77,29,36,38 D12,25,71,68,33,34 5AVL树是一种平衡的二叉排序树,树中任一结点的A左、右子树的高度均相同 B. 左、右子树高度差的绝对值不超过1C. 左子树的高度均大于右子树的高度 D. 左子树的高度均小于右子树的高度6. 以下关于查找方法的描述中,错误的是 A) 平衡二叉树一定也是二叉排序树。B) 有序表的折半查找判定树是二叉排序树。C) 中序遍历一棵二叉排序
20、树,可以得到其数据元素的升序排列。D) 后序遍历一棵二叉排序树,可以得到其数据元素的降序排列。7.下列二叉排序树中,满足平衡二叉树定义的是( )8、在下列所示的平衡二叉树中插入关键字48后得到一棵新平衡二叉树,在新平衡二叉树中,关键字37所在结点的左、右子结点中保存的关键字分别是( )A、13,48 B、24,48 C、24,53 D、24,909. 从理论上讲,将数据以何()结构存放,则查找一个数据所用时间不依赖于数据个数n.A)二叉查找数 B)链表 C)二叉树 D)哈希表10 为提高散列(Hash)表的查找效率,可以采取的正确措施是( )、增大装填(载)因子 、设计冲突(碰撞)少的散列函数
21、、处理冲突(碰撞)时避免产生聚集(堆积)现象A仅 B仅 C仅、 D仅、二、解答题1. 设记录关键字集合key=33,20,53,55,23,38,40,65,选取哈希函数为H(x)=key mod 11;解决冲突的方法为“线性探测法”。(1)请按上述条件将key中各值依次填入下表中:(2)求该哈希表查找成功和查找不成功情况下的平均查找长度。2. 设记录关键字集合key=32,13,49,55,22,39,20,选取哈希函数为H(x)=key mod 7;解决冲突的方法为“链地址法”。(1)画出所构造的哈希表;(2)求该哈希表查找成功和查找不成功情况下的平均查找长度。3. 设记录关键字集合key
22、=32,13,49,55,22,39,20,解决冲突的方法为“线性探测法”,要求装填因子为:0.7,哈希函数的形式为H(x)=key mod P,散列表的地址从0开始。(1)构造哈希函数;(2)画出所构造的哈希表;(2)求该哈希表查找成功和查找不成功情况下的平均查找长度。4. 选取哈希函数H(key)=(3*key) mod 11。用开放定址法处理冲突,di=i(7*key) % 10+1)(i=1,2,3)。试在010的散列地址空间对关键字序列(22,41,53,46,30,13,01,67):1) 构造该序列对应的哈希表;2) 求等概率情况下查找成功的平均查找长度。哈希表如下图所示:5.
23、从空树开始,依次插入13,34,51,24,62,43,75,18,画出建立2-3树后的状态,并分别画出删除43、24后的2-3树状态。6. 画出对长度为12的有序表进行折半查找的判定树,并求其等概率查找成功时的平均查找长度。第十章一、 单选或填空题1. 数组中原有数据如下:15,13,20,18,12,60。下面是一组用不同排序方法进行一趟排序后的结果。则ABCD四个选项中,说法正确的是 I 12,13,15,18,20,60 II 13,15,18,12,20,60III 13,15,20,18,12,60 IV 12,13,20,18,15,60V 13,15,18,20,12,60A)
24、 I快速排序;II简单选择排序;III直接插入排序;IV冒泡排序;V归并排序B) I冒泡排序;II快速排序;III归并排序;IV简单选择排序;V直接插入排序C) I快速排序;II冒泡排序;III直接插入排序;IV简单选择排序;V归并排序D) I直接插入排序;II归并排序;III快速排序;IV简单选择排序;V冒泡排序 2. 对一组数据(2,12,16,88,5,10)进行排序,若前三趟排序结果如下:第一趟:2,12,16,5,10,88第二趟:2,12,5,10,16,88第三趟:2,5,10,12,16,88则采用的排序方法可能是( )A.冒泡排序法 B.希尔排序法 C.归并排序法 D.基数排
25、序法3. 若一组记录的排序码为(45,78,56,36,40,87),则初始小根堆的结果为A36,45,56,78,40,87 B87,78,56,36,40,45C40,36,45,56,78,87 D36,40,56,78,45,874已知序列25,13,10,12,9是大根堆,在序列尾部插入新元素18,将其再调整为大根堆,调整过程中元素之间进行的比较次数是( ) A1 B2 C4 D55. 已知关键序列 5,8,12,19,28,20,15,22 是小根堆(最小堆),插入关键字 3,调整后得到的小根堆是A3,5,12,8,28,20,15,22,19B. 3,5,12,19,20,15,
26、22,8,28C3,8,12,5,20,15,22,28,19D. 3,12,5,8,28,20,15,22,196. 设有字符序列(Q,H,C,Y,P,A,M,S,R,D,F,X),新序列(F,H,C,D,P,A,M,Q,R,S,Y,X)是哪一个排序算法一趟排序的结果?A) 起泡排序 B) 初始步长为5的希尔排序 C) 2-路归并排序 D) 以第一元素为枢轴的快速排序7. 下列排序算法中属于不稳定的排序方法是 A)直接插入排序 B)冒泡排序 C)简单选择排序 D)归并排序8下列排序方法的时间复杂度不为线性对数阶的是 。A)快速排序 B)2-路归并排序 C)希尔排序 D) 堆排序9最好和最坏时
27、间复杂度均为O(nlogn)且稳定的排序方法是 。A)快速排序 B)2-路归并排序 C)希尔排序 D) 堆排序10. 对于快速排序,若初始关键字有序排列,则时间复杂度为 。11分别采用堆排、快序速排序、直接插入排序和归并排序算法对初始状态为递增序列的表按递增顺序排序,最省时间的是 算法。二、 解答题1. 已知待排序的序列为37,65,56,8,76,3,89,34,21,46,试完成下列各题(本题排序均指非递减有序排列):(1) 写出希尔排序每一趟排序的结果;(d1=5,d2 = 3,d3 = 1) (2) 写出第一趟快速排序过程及结果。(3)画出初始堆,以及第一次交换后,经过堆调整重新形成的
28、堆。2. 已知待排序的序列为37,65,56,8,76,3,89,34,21,46,试完成下列各题(本题排序均指非递减有序排列):(1) 写出直接插入排序每一趟排序的结果; (2) 写出2路归并排序每一趟排序的结果。参考答案:第一章-第五章一单选与填空1. n(n-1)/2 2.O(n) 3.常数阶 O(n) 4.C 5.A 6.C 7.D 8.A 9. O(n) 10.B 11.C 12.A 13.A 14.B 15.C 16.L-next=NULL 17. P-prior-next=P-next P- next - prior =P-prior18.B 19.D 20.D 21.3 22.C 23.A 24.B 25.A 26.C 27. (rear-front+m)%m 28.D29. I have a dream , ave 30. 6 31. 1116,1040 32.B 33.D 34.(a,b) (c,( )第六章一单选与填空1.C 2. 150 3.C 4.mi-1 5.A 6.D 7.D 8. 86 9.A
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1