数据结构 复习题.docx

上传人:b****4 文档编号:24636996 上传时间:2023-05-29 格式:DOCX 页数:28 大小:127.18KB
下载 相关 举报
数据结构 复习题.docx_第1页
第1页 / 共28页
数据结构 复习题.docx_第2页
第2页 / 共28页
数据结构 复习题.docx_第3页
第3页 / 共28页
数据结构 复习题.docx_第4页
第4页 / 共28页
数据结构 复习题.docx_第5页
第5页 / 共28页
点击查看更多>>
下载资源
资源描述

数据结构 复习题.docx

《数据结构 复习题.docx》由会员分享,可在线阅读,更多相关《数据结构 复习题.docx(28页珍藏版)》请在冰豆网上搜索。

数据结构 复习题.docx

数据结构复习题

数据结构复习题

一、填空题

1.数据结构是一门研究非数值计算的程序设计问题中计算机的操作对象以及它们之间的关系和运算等的学科。

2.数据结构被形式地定义为(D,R),其中D是数据元素的有限集合,R是D上的关系有限集合。

3.数据结构包括数据的逻辑结构、数据的存储结构和数据的运算这三个方面的内容。

4.数据结构按逻辑结构可分为两大类,它们分别是线性结构和非线性结构。

5.线性结构中元素之间存在一对一关系,树形结构中元素之间存在一对多关系,图形结构中元素之间存在多对多关系。

6.在线性结构中,第一个结点没有前驱结点,其余每个结点有且只有1个前驱结点;最后一个结点没有后续结点,其余每个结点有且只有1个后续结点。

7.在树形结构中,树根结点没有前驱结点,其余每个结点有且只有1个前驱结点;叶子结点没有后续结点,其余每个结点的后续结点数可以任意多个。

8.在图形结构中,每个结点的前驱结点数和后续结点数可以任意多个。

9.数据的存储结构可用四种基本的存储方法表示,它们分别是顺序、链式、索引和散列。

10.数据的运算最常用的有5种,它们分别是插入、删除、修改、查找、排序。

11.一个算法的效率可分为时间效率和空间效率。

12.在顺序表中插入或删除一个元素,需要平均移动表中一半元素,具体移动的元素个数与表长和该元素在表中的位置有关。

13.线性表中结点的集合是有限的,结点间的关系是一对一的。

14.向一个长度为n的向量的第i个元素(1≤i≤n+1)之前插入一个元素时,需向后移动n-i+1个元素。

15.向一个长度为n的向量中删除第i个元素(1≤i≤n)时,需向前移动n-i个元素。

16.在顺序表中访问任意一结点的时间复杂度均为O

(1),因此,顺序表也称为随机存取的数据结构。

17.顺序表中逻辑上相邻的元素的物理位置必定相邻。

单链表中逻辑上相邻的元素的物理位置不一定相邻。

18.在单链表中,除了首元结点外,任一结点的存储位置由其直接前驱结点的链域的值指示。

19.在n个结点的单链表中要删除已知结点*p,需找到它的前驱结点的地址,其时间复杂度为O(n);还有一种时间复杂度为O

(1)的巧妙删除方法,即把p的后继结点中数据拷贝到p结点中,然后删除p的后继结点,删除语句应该是q=p->next;p->next=q->next;free(q);。

20.向量、栈和队列都是线性结构,可以在向量的任何位置插入和删除元素;对于栈只能在栈顶插入和删除元素;对于队列只能在队尾插入和队首删除元素。

21.栈是一种特殊的线性表,允许插入和删除运算的一端称为栈顶。

不允许插入和删除运算的一端称为栈底。

22.队列是被限定为只能在表的一端进行插入运算,在表的另一端进行删除运算的线性表。

23.不包含任何字符(长度为0)的串称为空串;由一个或多个空格(仅由空格符)组成的串称为空白串。

24.子串的定位运算称为串的模式匹配;被匹配的主串称为目标串,子串称为模式。

25.假设有二维数组A6×8,每个元素用相邻的6个字节存储,存储器按字节编址。

已知A的起始存储位置(基地址)为1000,则数组A的体积(存储量)为288B;末尾元素A57的第一个字节地址为1282;若按行存储时,元素A14的第一个字节地址为(8+4)×6+1000=1072;若按列存储时,元素A47的第一个字节地址为(6×7+4)×6+1000)=1276。

26.由3个结点所构成的二叉树有5种形态。

27.一棵深度为6的满二叉树有n1+n2=0+n2=n0-1=31个分支结点和26-1=32个叶子。

解:

满二叉树没有度为1的结点,所以分支结点数就是二度结点数。

28.一棵具有257个结点的完全二叉树,它的深度为9。

解:

用ëlog2(n)û+1=ë8.xxû+1=9

29.设一棵完全二叉树有700个结点,则共有350个叶子结点。

解:

最快方法:

最后一个叶子编号为700,其父节点编号为[n/2]=350,且其父节点为最后一个非叶子结点。

30.设一棵完全二叉树具有1000个结点,则此完全二叉树有500个叶子结点,有499个度为2的结点,有1个结点只有非空左子树,有0个结点只有非空右子树。

解:

方法同上:

最后一个非叶子编号为[n/2]=500,所以叶子结点数n0=500,n2=n0-1=499。

另外,最后一个结点为2i属于左叶子,右叶子是空的,所以有1个非空左子树。

完全二叉树的特点决定不可能有左空右不空的情况,所以非空右子树数=0.也可根据编号为500的左右儿子结点应该为1000和1001,而显然1001不存在。

31.在数据的存放无规律而言的线性表中进行检索的最佳方法是顺序查找(线性查找)。

32.线性有序表(a1,a2,a3,…,a256)是从小到大排列的,对一个给定的值k,用二分法检索表中与k相等的元素,在查找不成功的情况下,最多需要检索8次。

设有100个结点,用二分法查找时,最大比较次数是7。

33.假设在有序线性表a[20]上进行折半查找,则比较一次查找成功的结点数为1;比较两次查找成功的结点数为2;比较四次查找成功的结点数为8;平均查找长度为3.7。

解:

显然,平均查找长度=O(log2n)<5次(25)。

但具体是多少次,则不应当按照公式

来计算(即(21×log221)/20=4.6次并不正确!

)。

因为这是在假设n=2m-1的情况下推导出来的公式。

应当用穷举法罗列:

全部元素的查找次数为=(1+2×2+4×3+8×4+5×5)=74;ASL=74/20=3.7

34.折半查找有序表(4,6,12,20,28,38,50,70,88,100),若查找表中元素20,它将依次与表中元素28,6,12,20比较大小。

35.在各种查找方法中,平均查找长度与结点个数n无关的查找方法是散列查找。

36.散列法存储的基本思想是由关键字的值决定数据的存储地址。

37.数据的逻辑结构可分为集合结构、_线性结构_、__树形结构__和__图形结构_等4种。

38.从长度为n的采用顺序存储结构的线性表中删除第i个元素(1≤i≤n),需要移动

n-i个元素,在第i个元素前面插入一个元素,需要移动n-i+1个元素。

39.顺序存储的栈,做入栈运算时,应先判断栈是否为满,做出栈运算时,应先判断栈是否为空。

40.已知一个栈的进栈先后次序为abcd,判断下面两个序列能否是其出栈序列:

(1)dbca不能

(2)cbda能(注:

填“能”或者“不能”)

41.长度为0的字符串称为_空串_。

设正文串长度为n,模式串长度为m,则简单模式匹配算法的时间复杂度为__O(n*m)_。

42.设广义表L=((),()),则GetHead(L)是();GetTail(L)是(());L的长度是2;L的深度是2。

43.由带权为3,9,6,2,5的5个叶子结点构成一棵哈夫曼树,则带权路径长度为_55_。

44.完全二叉树的第7层有8个结点,则此完全二叉树的叶子结点数为_36_。

768个结点的完全二叉树有_384_个叶子结点?

19个结点的哈夫曼树有_10_个叶子结点?

45.n个顶点的无向连通图,用邻接矩阵存储时,该矩阵至少有2n-2个非零元素。

46.希尔排序的增量序列有多种选择,但不管哪种选择,最后一个增量必须为__1__。

47.假设以S和X分别表示入栈和出栈操作,则对输入序列a,b,c,d,e进行一系列栈操作SSXSXSSXXX之后,得到的输出序列为_bceda_。

48.组成串的数据元素只能是_字符_。

49.n个结点的完全二叉树,编号最大的非叶结点是_[n/2]_号结点,编号最小的叶结点是_[n/2]+1_号结点。

50.已知二叉树有50个叶子结点,则该二叉树的总结点数至少是99。

51.在一棵二叉树中,度为0的结点个数为N0,则度为2的节点个数为N0-1。

52.叶子权值(5,6,17,8,19)所构造的哈夫曼树带权路径长度为121。

53.深度为k的完全二叉树至少有2k-1个结点,至多有2k-1个结点。

54.在n个元素的线性表中顺序查找,若查找成功,则关键字的比较次数最多为n_次;使用监视哨时,若查找失败,则关键字的比较次数为n+1次。

55.折半搜索只适合用于__有序的顺序存储表__。

56.结点关键字转换为该结点存储单元地址的函数H称为_哈希函数_或叫_散列函数_。

57.在一棵k叉树中,度为i(0<=i<=k)的结点的个数为Ni,则有N0=

解:

所有结点数记为n,结合树中分支数比结点数少一个,以及每一个分支被计入顶点的度1次,则有

n=N0+N1+…+Nk

n-1=1*N1+2*N2+…k*Nk//所有结点度数的和

两式相减即得。

58.设一棵完全二叉树叶子结点数为k,最后一层结点数为偶数时,则该二叉树的高度为;最后一层结点数为奇数时,则该二叉树的高度为。

解:

根据完全二叉树性质,结点数为n的完全二叉树,其深度为

【或者

+1】,所以只要推算出二叉树结点即可。

对完全二叉树从根(编号1)开始,逐层递增编号,最后一个结点编号为n,则n的父结点为最后一个非叶子结点,其编号为[n/2],也就是说,完全二叉树中非叶子结点个数为[n/2],比如n=4或5的完全二叉树,其飞叶子结点数均为2;从而可以看出叶子结点数比非叶子结点数,要么相等,要么多1个,因为完全二叉树除去除去最后一层,上面的为满二叉树(其结点数为奇数),所以当最后一层结点数为偶数时,说明完全二叉树总结点数为奇数,因为叶子结点数为k,则非叶子结点数为k-1,总结点数为2k-1,树深度为

=

当最后一层结点数为奇数时,说明总结点数为偶数,此时叶子结点与非叶子结点数相等,所以总结点数为2k,则树深度为

59.有5种不同形态的二叉树可以按照中序遍历得到相同的abc序列。

解:

根据二叉树5种基本形态,中根遍历为abc,

当根为a时,bc在其右子树,有如图2种情况,

当根为b时,a在其左子树,c在其右子树,有如图1种情况,

当根为c时,ab在其左子树,有如图2种情况,

60.已知二叉树先序为ABDEGCF,中序为DBGEACF,则后序一定是DGEBFCA。

解:

先画出二叉树,然后写出后根序列。

61.深度为k的完全二叉树至少有2k-1个结点,至多有2k-1个结点。

解:

结点数最少时,第k层仅1个结点,加上上面k-1层满二叉树结点数。

结点数最多时,即为k层的满二叉树。

62.具有10个叶子的哈夫曼树,其最大高度为,最小高度为。

解:

哈夫曼树只有度为0和2的结点,且有N0=N2+1,所以哈夫曼树结点数共有19个,

最小高度时为完全二叉树,即为[log2(19)]+1=5;

最大高度时,从根到倒数第二层均只有一个非叶子结点,所以高度为10,形状如下

63.设F是一个森林,B是由F转换得到的二叉树,F中有n个非终端结点,则B中右指针域为空的结点有n+1个。

解:

举例子推理,即可发现规律。

先对一棵一般树转换,可发现空的右指针数总比非叶子结点数多1个,那么2棵一般树转换成2棵对应二叉树时,空的右指针数比非叶子结点数多2个,但是在转换为森林时,后一棵二叉树接到前一棵二叉树的根右边,从而又会减少一个空的右指针,所以最终空的右指针数总比非叶子结点数多1个。

64.在线性表(5,12,19,21,37,56,65,75,80,88,92)中,用折半查找法查找关键字为85的记录,关键字的比较次数为次,所比较的元素依次为。

答案:

3568088

65.假定对长度n=100的线性表进行分块查找,并假定每块的长度均为10,每个记录的查找概率相等。

若索引表和块内都采用顺序查找,则平均查找长度为;若索引表采用折半查找,块内采用顺序查找,则平均查找长度约为。

答案:

119

66.已知二叉排序树的左右子树均不为空,则_左子树_上所有结点的值均小于它的根结点值,___右子树_上所有结点的值均大于它的根结点的值。

67.二叉排序树的查找效率与树的形态有关。

当二叉排序树退化成成单支树时,查找算法退化为__________查找,其平均查找长度上升为_________。

当二叉排序树是一棵平衡二叉树时,其平均查找长度为_________。

答案:

顺序(n+1)/2O(log2n)

68.希尔排序的增量序列有多种选择,但不管哪种选择,最后一个增量必须为_________。

答案:

1

69.排序算法所花费的时间,通常用在数据的比较和_移动_两大操作上。

二、单项选择题

1.程序段for(i=n-1;i>=0;i--)

for(j=1;j<=n;j++)

ifA[j]>A[j+1]

A[j]与A[j+1]对换;

其中n为正整数,则最后一行的语句频度在最坏情况下是()。

A.O(n)B.O(n2)C.O(n3)D.O(nlog2n)

2.线性表中在链式存储中各结点之间的地址()。

A.必须连续B.部分地址必须连续C.不能连续D.连续与否无所谓

3.将两个各有n个元素的有序线性表归并成一个有序线性表,最少的比较次数是()。

A.nB.2n-1C.2nD.n-1

4.在有n个结点的单链表中查找值为x的结点,在查找成功情况下,需平均比较()个结点。

A.nB.n/2C.(n-1)/2D.(n+1)/2

5.若希望从链表中快速确定一个结点的前驱,则链表最好采用()方式。

A.单链表B.循环单链表C.双向链表D.任意

6.带头结点的单链表head为空的判定条件是()。

A.head==NULLB.head->next==NULLC.head->next==headD.head!

=NULL

7.在循环双链表的p所指结点之后插入s所指结点的操作是()。

A.p->next=s;s->prior=p;p->next->prior=s;s->next=p->next;

B.p->next=s;p->next->prior=s;s->prior=p;s->next=p->next;

C.s->prior=p;s->next=p->next;p->next=s;p->next->prior=s;

D.s->prior=p;s->next=p->next;p->next->prior=s;p->next=s;

8.设有—顺序栈S,元素s1,s2,s3,s4,s5,s6依次进栈,如果6个元素出栈的顺序是s2,s4,s3,s6,s5,s1,则栈的容量至少应该是____________。

A.3B.4C.5D.6

9.在—个栈顶指针为top的链栈中,将一个s指针所指的结点入栈,执行____________。

A.top->next=s:

B.s->next=top->next;top->next=s;

C.s->next=top;top=s;D.s->next=top;top=top->next;

10.链栈和顺序栈相比,有一个比较明显的优点,即____________。

A.插入操作更加方便B.通常不会出现栈满的情况

C.不会出现栈空的情况D.删除操作更加方便

11.循环队列A[m]存放其元素,用front和rear分别表示队头及队尾,则循环队列满的条件是_________。

A.(Q->rear+1)%m==Q->frontB.Q->rear==Q->front+1

C.Q->rear+1==Q->frontD.Q->rear==Q->front

12.若一个栈的输入序列为1,2,3,…,n,输出序列的第一个元素是n,则第i个输出元素是()。

A.n-i-1B.n-iC.n-i+1D.不确定

13.设abcdef以所给的次序进栈,若在进栈操作时,允许出栈操作,则下面得不到的序列为()。

A.fedcbaB.bcafedC.dcefbaD.cabdef

14.中缀表达式A-(B+C/D)*E的后缀形式是()。

A.AB-C+D/E*B.ABC+D/E*C.ABCD/E*+-D.ABCD/+E*-

15.假设以数组A[m]存放循环队列的元素,其头尾指针分别为front和rear,则当前队列中的元素个数为()。

A.(rear-front+m)%mB.rear-front+1

C.(front-rear+m)%mD.(rear-front)%m

16.循环队列存储在数组A[0..m]中,则入队时队尾的操作为()。

A.rear=rear+1B.rear=(rear+1)%(m-1)

C.rear=(rear+1)%mD.rear=(rear+1)%(m+1)

17.下面关于串的叙述中,哪一个是不正确的?

_________

A.串是字符的有限序列B.空串是由空格构成的串

C.模式匹配是串的一种重要运算D.串既可以采用顺序存储,也可以采用链式存储

18.已知串S="aaab",其next数组值为_________。

A.0,1,2,3B.1,1,2,3C.1,2,3,1D.1,2,1,1

19.一维数组A采用顺序存储结构,每个元素占用6个字节,第6个元素的起始地址为100,则该数组的首地址是。

A.64B.28C.70D.90

20.稀疏矩阵采用压缩存储的目的主要是______________。

A.表达变得简单B.对矩阵元素的存取变得简单

C.去掉矩阵中的多余元素D.减少不必要的存储空间的开销

21.若对n阶对称矩阵A以行序为主序方式将其下三角形的元素(包括主对角线上所有元素)依次存放于一维数组B[1..(n(n+1))/2]中,则在B中确定aij(i

A.i*(i+1)/2+jB.j*(j+1)/2+iC.i*(i+1)/2+j+1D.j*(j+1)/2+i+1

22.已知广义表LS=((a,b,c),(d,e,f)),运用GetHead和GetTail运算取出LS中的元素e的运算是。

A.GetHead(GetTail(LS))B.GetHead(GetTail(GetTail(GetHead(LS))))

C.GetTail(GetHead(LS))D.GetHead(GetTail(GetHead(GetTail(LS))))

23.设广义表L=((a,b,c)),则L的长度和深度分别为。

A.1和1B.1和3C.1和2D.2和3

24.一个100*90的稀疏矩阵,非0元素有10个整型数,设每个整型数占2字节,则用三元组表示该矩阵时,所需的字节数是_____________。

A.60B.66C.18000D.33

25.设二维数组A[1..m,1..n](即m行n列)按行存储在数组B[1..m*n]中,则二维数组元素A[i][j]在一维数组B中的下标为()。

A.(i-1)*n+jB.(i-1)*n+j-1C.i*(j-1)D.j*m+i-1

26.一棵三叉树中,已知度为3的结点数等于度为2的结点数,且树中叶结点的数目为13,则度为2的结点数目为____________。

A.4  B.2  C.3  D.5

27.设n、m为一棵二叉树上的两个结点,在中序遍历时,n在m之前的条件是____________。

A.n在m右方B.n是m祖先C.n在m左方D.n是m子孙

28.对一个满二叉树,m个树枝,n个结点,深度为h,则____________。

A.n=h+mB.h+m=2nC.m=h-1D.n=2h-1

29.以二叉链表作为二叉树的存储结构,在有n个结点的二叉链表中(n>0),链表中空链域的个数为____________。

A.2n-1B.n-1C.n+1D.2n+1

30.在一棵二叉树结点的先序序列、中序序列、后序序列中,所有叶子结点的先后顺序__________。

A.都不相同B.先序和中序相同,而与后序不同

C.完全相同D.中序和后序相同,而与先序不同

31.如果将给定的一组数据作为叶子数值,所构造出的二叉树的带权路径长度最小,则该树称为____________。

A.哈夫曼树B.平衡二叉树C.二叉树D.完全二叉树

32.树的先根序列和其对应的二叉树的是一样的,树的后根序列和其对应的二叉树的是一样的。

A.先序序列B.中序序列C.后序序列D.按层次遍历序列

33.若一个具有N个顶点,K条边的无向图是一个森林(N>K),则该森林中必有_____棵树。

A.KB.NC.N-KD.1

34.如果T2是由树T转换而来的二叉树,那么对T中结点的后序遍历就是对T2中结点的

()遍历。

A.先序B.中序C.后序D.层次序

35.设树T的度为4,其中度为1,2,3和4的结点个数分别为4,2,1,1则T中的叶子数为()。

A.5B.6C.7D.8

36.由4个结点可以构造出多少种不同的二叉树?

()

A.10B.12C.14D.16

37.二叉树在线索后,仍不能有效求解的问题是()。

A.先序线索二叉树中求先序后继B.中序线索二叉树中求中序后继

C.中序线索二叉树中求中序前驱D.后序线索二叉树中求后序后继

38.一棵二叉树具有10个度为2的结点,5个度为1的结点,则度为0的结点个数是()。

A.9B.11C.15D.不确定

39.设高度为h的二叉树上只有度为0和度为2的结点,则此类二叉树中所包含的结点数至少为()个。

A.2hB.2h-1C.2h+1D.h+1

40.设给定权值的叶子总数有n个,其哈夫曼树的结点总数为()。

A.不确定B.2nC.2n+1D.2n-1

41.某二叉树的先序遍历序列和后序遍历序列正好相反,则此二叉树一定是()。

A.空或只有一个结点B.完全二叉树C.单支树  D.高度等于结点数

42.在二叉树结点的先序序列,中序序列和后序序列中,所有叶子结点的先后顺序()。

A.都不相同  B.完全相同

C.先序和中序相同,而与后序不同 D.中序和后序相同,而与先序不同

43.根据使用频率,为5个字符设计的哈夫曼编码不可能是()。

A.111,110,10,01,00B.000,001,010,011,1

C.100,11,10,1,0D.001,000,01,11,10

44.具有7个顶点的有向图至少应有____________条边才能确保一个强连通图。

A.6B.7C.8D.9

45.设无向图的顶

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 求职职场 > 自我管理与提升

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1