《数据结构》试题库中的习题Word文件下载.docx

上传人:b****5 文档编号:16211650 上传时间:2022-11-21 格式:DOCX 页数:16 大小:45.04KB
下载 相关 举报
《数据结构》试题库中的习题Word文件下载.docx_第1页
第1页 / 共16页
《数据结构》试题库中的习题Word文件下载.docx_第2页
第2页 / 共16页
《数据结构》试题库中的习题Word文件下载.docx_第3页
第3页 / 共16页
《数据结构》试题库中的习题Word文件下载.docx_第4页
第4页 / 共16页
《数据结构》试题库中的习题Word文件下载.docx_第5页
第5页 / 共16页
点击查看更多>>
下载资源
资源描述

《数据结构》试题库中的习题Word文件下载.docx

《《数据结构》试题库中的习题Word文件下载.docx》由会员分享,可在线阅读,更多相关《《数据结构》试题库中的习题Word文件下载.docx(16页珍藏版)》请在冰豆网上搜索。

《数据结构》试题库中的习题Word文件下载.docx

路径长度为______________。

26、在一个图中,若两个顶点间存在路径,则这两个顶点________________是相

邻接。

27、在对一个有向图进行拓扑排序结束后,发现输出顶点个数为0,那么,该图一定是一个图。

28、分块查找的索引表中的关键字是___________有序的。

所以,在索引表中确定给定值所在块时,可以用___________查找方式。

29、在构造二叉排序树时,若新结点插在左重结点左孩子的左分支上,则称为___________型。

用____________旋转的方法调整。

30、哈希表查找,从原理上讲,查找时间只与被查记录的__________有关,而与表的_______无关。

31、影响哈希表查找时间的因素有__________________,_________________。

32、哈希表查找的主要缺点是____________,解决的办法通常有下列四种

其一,_________________;

其二,_______________;

其三,______________;

其四,_____________。

33、在实际工作中选择∂小于1的目的是为了__________冲突。

34、哈希表查找成功的平均查找长度是对所有记录查找成功时总的比较次数与_____________________的比值。

35、哈希表查找不成功的平均查找长度是对所有记录查找不成功时总的比较次数与_____________________的比值。

36、排序时,若待排序记录能一次全部调入内存进行排序的方式,

一般称__________________排序。

37、平均时间量级为O()的排序方法有________,___________,_____________。

38、希尔排序是属于___________,但它不是稳定排序。

39、磁带文件只能是______________。

40、顺序文件分为___________文件____________文件。

它们分别对应于线性表的顺序存储和链式存储。

41、一棵M叉的树中,结点的度最多有____________种。

42、一棵高度为N的树中,结点的最大__________为N。

43、构成森林的每棵子树的根结点是__________关系。

45、有序树中每个结点的孩子结点的_______________是固定的。

46、一棵具有N个结点的完全二叉树中,叶子结点的最大________________为N。

47、磁带文件批处理时,待修改的原文件称为_____________。

所有的修改申请构成一

个___________。

这两个文件是有序文件。

它们利用的方式形成新___________。

48、一棵二叉树中结点的度有__________,______________,________________,三种。

49、哈(霍、赫)夫曼树中结点的度,只有_________,_____________两种。

50、从连通图的定义出发,树是一个没有________________的连通图。

51、B-树的叶子结点为___________结点,它们必须在_____________层上。

52、除根为叶子结点外,根结点至少有_________棵子树。

53、M阶的B–树中,非叶子结点上最多有____________个关键字。

54、M阶的B–树中,非叶子结点上最少有______________个关键字。

55、N阶B+树中,结点上有_______________个关键字。

56、在B+树上查找记录时,可以,从_____________开始按索引方式查找也可以从_______________开始按顺序查找。

57、在计算机科学中常用的数据结构有__________________,____________,____________________,_____________。

58、栈的操作特点是先进后出;

队列的操作特点是先进先出。

59、线性表的顺序存储,要求每个数据元素都占用相同的存储单元数。

60、线性表的顺序存储可以用顺序查找,也可以用___________查找。

61、线性表的顺序存储的缺点是在任意位置上插入数据与删除数据费时间。

62、在实际应用中,一般最多建立___________级索引。

63、线性表的顺序存储可以用顺序查找,也可以用__________查找。

64、线性表的顺序存储的缺点是在任意位置上插入数据与删除数据费时间。

65、线性表的顺序存储是用一组物理连续的空间单元实现数据元素的存储。

66、编写在内存中生成线性表(a1a2a3…an)的算法。

(判断表是否满了)

67、已知线性表(a1a2a3…an)以顺序的方式存储在内存,编写在表中查找值为X的元素,若存在把它与其直接前驱元素交换,否则把X插到表尾的算法。

并计算该算法的时间复杂性.(如果是a1就不交换)(可用while语句做)

68、编写把线性表(a1a2a3…an)的顺序完全倒置的算法。

并计算该算法的时间复杂性及决定时间复杂性的语句频度。

(对称交换)

69编写把从线性表(a1a2a3…an)中值为X的元素开始到的所有元素顺序倒置的算法。

70、线性表的链式存储C语言是用语句实现空间单元动态分配。

71、设一线性表的顺序存储,总存储容量为M,其指针的变化范围为——。

(0~M-1)

72、线性表的顺序存储,要求每个数据元素都占用的存储单元。

73、头结点地址指针为L的循环单链表,空表的判别标志是。

74、头结点地址指针为L1的双循环链表,空表的判别标志是。

75、含有N个结点的一棵完全二叉树上,叶子结点的最小编号是________。

76、后根序序列和中根序序列相同的二叉树是树中每个结点只有左孩子结点的二叉树。

77、先根序序列、中根序序列和后根序序列均相同的二叉树是空树或者是只有一个结点的二叉树。

78、判定一棵线索二叉树中未知结点P没有左孩子的标志是。

79、线索二叉树是利用结点中空闲字段来记录次序的二叉树。

80、高度为K的一棵完全二叉树中,结点的总个数至少是个;

至多是个。

给出二叉树的先根序序列和中根序序列,便能唯一的确定这棵二叉树。

81、先根序序列和中根序序列相同的二叉树是树中每个结点只有左孩子结点的二叉树。

82、在一棵中序线索二叉树中已知在结点P的左侧插入一个新结点Y后

仍然是一棵中序线索二叉树的操作,主要是查找P的前驱结点。

83、高度为K的一棵完全二叉树中,结点的总个数至少是个;

至多是个。

84、一棵M叉的树中,结点的度最多有种。

85、一棵高度为N的树中,结点的最大为N。

86、一棵具有N个结点的完全二叉树中,叶子结点的最大_______为N。

87、构成森林的每棵子树的根结点是兄弟关系。

88、有序树中每个结点的孩子结点的是固定的。

89、含有N个结点的一棵完全二叉树上,叶子结点的最小编号是。

 

二、完成下列各题

1、知A为二维数组,A[-12,-23],按顺序存储,基址为999,每个元素都占用4个存储单元,分别计算元素A(-1,-1)按行(列)优先存储的地址号。

(写出计算公式)

2、知S=“aabbbccaabccaabc”,t=‘xxyy’;

m=ASSIGN(m,SUBSTR(S,LEN(t)));

i=INDEX(m,SUBSTR(S,6,LEN(t)));

求REPLACE(m,SUBSTR(m,i,LEN(t),t)))=?

3、知广义表A=((((a))),b,(d,((f)),c),((e),g,((h)))),求A的长度与深度;

4)设有‘abcd’,按顺序进入一个栈,试写出所有可能的输出序列。

5)设有‘abcde’,经过一个栈的处理得到输出序列为‘cdbea’。

假设,用P代表一次进栈操作,Q代表一次退栈操作。

要求,写出用PQ序列表示得到上述输出结果的过程。

6)假设三维数组A,它的各维界偶分别为(4,9),(-1,5),(-9,-2),基地址为20,每个元素占三个存储单元,试计算元素A[6,0,-5]的存储位置。

7)写出head(tail(head(((a,b),c,d))))和tail(head(tail((a,(b,c,d)))))各自的运算结果。

画出A的图形表示及一种存储结构图;

写出用求头、尾元素的方式求出单元素h的过程。

8、知一棵二叉树的先根序、中根序序列分别为‘123456789‘,’243168975’,试画出这棵二叉树。

9、知一棵完全二叉树的结点个数为20到40之间的素数,求该二叉树的叶子结点个数。

10、知一有向图G,用n*n维邻接矩阵表示,据此回答下列问题:

1)该图中边的条数为多少?

2)任一顶点的V的入度、出度是多少?

3)若用邻接表方式存储图G,应构成多少个单链表?

11、知一无向图G,用n*n维邻接矩阵表示,据此回答下列问题:

2)任一顶点的V度是多少?

12、假设N为一棵结点的度只有0和2的二叉树中叶子结点的个数,M为树中结点的总个数,证明:

M=2*N–1。

13、设一棵具有N个结点的二叉树用链式存储,每个结点都含有左右孩子指针域和数据域,证明:

该树中共空闲N+1个字段。

14、知算术表达式为A*(B–C)/E+F*G–H/(I+J),用学过的方法把它划

成一棵二叉树。

然后,再画成按后序遍历的线索二叉树。

15、知要传输的数据为字符串“AABBBBAAAACCCDDCC”,试画出哈夫曼树并求出数据中每种符号的哈夫曼编码。

16、知A,B,C,D,E为高度为3的一棵三叉树上的结点,也是由这棵三叉树转换成的高度为4的一棵二叉树上的结点,试画出满足上述两条件的所有三叉树和二叉树。

17、知关键字集合(60,70,50,40,30,55,58)按顺序输入构成一棵平衡二叉排序树,画出中间出现的各不平衡树,并说明属于何种类型;

画出最后的平衡二叉排序树。

18、判断关键字集合(20,45,60,55,70,90,80,75)是否是堆树,若不是画出按顺序输入构成的树及整理成的堆树。

然后再画出输出一个排序结果的树及调整后的堆。

19、设某系学生举办运动会,参加同学的学号为(9301,9382,9372,9324,

9345,9248,9262,9207,9223,9246,9152,9162,9109,9147,9118)。

画出其块大小为5的分块查找的数据结构图。

20、设关键字集合(16,87,54,70,75,26,63,29,32,52,53,78),

a=0、75,设计一种散列函数,将它们进行散列,画出散列表并计算查找成功时的平均查找长度。

21、在实际工作中顺序栈有两种,一种是我们讲过的栈顶移动的栈。

另一种是栈底移动的栈。

但一般都不用第二种方式,请回答为什么?

22、设有‘abcd’,按顺序进入一个栈,试写出所有可能的输

出序列。

23、高度为K的一棵完全二叉树中,结点的总个数最多是多少?

最少

是多少?

24、设一棵满二叉树中,结点的总个数为20—40间的一个素数,

问满二叉树中共有多少个叶子结点?

25、一棵完全二叉树中结点的总个数是一个偶数,问该完全二叉树

中有多少个度为一的结点?

26、设一棵完全二叉树中结点i的堂兄弟结点的编号是2i+3,问该

堂兄弟结点的双亲结点编号是多少?

27、知A为二维数组,A[-12,-23],按顺序存储,基址为999

每个元素都占用4个存储单元,分别计算元素A(-1,-1)按行(列)

优先存储的地址号。

28、假设三维数组A,它的各维界偶分别为(4,9),(-1,5),(-9,-2),基地址为20,每个元素占三个存储单元,试计算元素A[6,0,-5]的存储位置。

29、写出head(tail(head(((a,b),c,d))))和tail(head(tail((a,(b,c,d)))))各自的

运算结果。

30、设有‘abcde’,经过一个栈的处理得到输出序列为‘cdbea’

求,写出用PQ序列表示得到上述输出结果的过程。

31、一棵完全二叉树中的某个结点,如果没有左孩子结点,则其一

定没有右孩子。

这种说法正确吗?

32、具有N个结点的一棵完全二叉树中,编号最小的叶子结点的编号

33、知A为二维数组,A[-12,-23],按顺序存储,基址为999

34、已知下边给出的两棵二叉树是由森林转换成的,现要求画出原森林。

35、用迪杰斯特拉算法,求右下图中从顶点V1到其他各顶点的最短路径,要求写出:

无图

(1)网的带权邻接矩阵;

(2)求最短路径的计算过程。

36、利用深度优先搜索的方法编写求无向图中通过给定顶点VK的简单回路的算法。

37、利用广度优先搜索思想编写求无向图中从V1顶点到VK顶点之间的最短路径(指边的条数)的算法。

38、根据右下图的AOE网络完成各题:

(1)求每个顶点的最早、晚时间;

(2)写出关键顶点;

(3)是否有哪项活动减少时间后能使整个工期缩短。

39、假设三维数组A,它的各维界偶分别为(4,9),(-1,5),(-9,-2),基地址为20,每个元素占三个存储单元,试计算元素A[6,0,-5]的存储位置。

40、写出head(tail(head(((a,b),c,d))))和tail(head(tail((a,(b,c,d)))))各自的运算结果。

41、已知T为一棵二叉树的根结点,按先序遍历该树的输出序列为‘ABDFGHCE’,按中序遍历该树的输出序列为‘BFDHGAEC’,要求画出这棵二叉树。

三.算法

1、已知L为单链表的头结点的地址指针,编写把L从第i个结点处分开形成两个带头结点的单链表的算法。

第1个结点为新表结点。

2、编写把一个值为X的结点插到表中地址为Y的结点之前的算法。

3、已知L为单链表的头结点的地址指针,数据结点值递增有序。

编写把表中从值大于X的结点开始到小于值为Y的结点之间的所有结点的顺序完全倒置的算法。

4、已知L为单链表的头结点的地址指针,表中结点的值都是正整数,编写把表中值为奇数的所有结点从表中删除并生成一个新的带头结点的单链表的算法。

(要求用的时间较少)

5、已知L为单链表的头结点的地址指针,编写把表中值X的结点的直接前驱结点删除的算法。

6、已知L为循环单链表的头结点指针,且每个结点都有一个空闲的前驱指针域,要求编写一个算法把该表变为循环双链表。

7、已知一个循环单链表,要求编写删除表中地址为Y的结点的直接前驱结点的算法。

8、已知L为循环单链表的头结点指针,要求编写把表从地址为Y的结点处分开,形成两个循环单链表的算法。

Y作为新表的第一个结点。

9、编写把一个循环双链表中已知结点P与其直接前驱结点位置交换的算法。

(要求只用一个辅助空间P)

10、已知一个循环单链表的尾结点地址P,问在该链表中能否执行首部删除、尾部插入结点的操作?

如何实现?

11、完成两个栈的设计以及进、退栈的算法。

12、完成将迷宫的算法编写成C语言的程序。

13、编写链式栈的进、退栈算法。

14、已知L为循环单链表的头结点地址指针,AV为另一单链表的第一个结点地址指针(如图示),要求用最少的时

间、用最少的操作完成把L表中的全部结点链接到链表AV中,并写出相应的算法。

15、求出子串‘NG’在字符串‘JIAOTONG’中的位置序号。

16、由下图1知,此时队列中的空间并非全部都被占用(若用循环队

列,这些空间可以被重新使用),现在,希望你想另外一种方法,

也能使这些空间可以被重新使用。

并设计实现进、出队列的算法。

17、编写一个计算循环队列中数据元素个数的算法。

(图2)

18、设有m个连续的存储单元,现分成由一个栈和一个队列使用。

和队列的容量不知且不相等。

要求在任何时刻,只要栈和队列中已存储

的元素个数之和小于m,便能满足用户的存放数据的申请。

试设计出

这种结构并写出进、出栈的算法。

19、已知T为一棵二叉树的根结点,设计把树中每个结点的左右孩子

结点交换的算法。

20、已知T为一棵二叉树的根结点,设计把树中每个单分支结点,用

添加数据值为0的新结点变为双分支结点的算法。

21、已知T为一棵二叉树的根结点,设计把树中值为X的结点找出,

并将它的两个孩子分别作为根生成两棵子树的算法。

22、已知T为一棵二叉树的根结点,设计计算该树高度(深度)的算

法。

23、已知T为一棵二叉树的根结点,树中结点的数据值都是正整数其

中只有一个值是寄数,设计找出该结点的算法。

24、已知T为一棵二叉树的根结点,设计计算该树中结点总个数的算法。

25、已知T为一棵中序线索二叉树的根结点指针,P为树中一个结点的地址,设计把一个新结点X插到结点P左侧(即作为P的左孩子)的算法。

26、设计把一个新结点X插到结点P右侧(即作为P的右孩子)的算法。

27、若把第一题中的新结点X改成是以X为根的一棵中序线索二叉树,设计把以X为根的一棵中序线索二叉树,插到结点P左侧(或右侧)的算法。

四.术语

1.数据结构

2.逻辑结构

3.存储结构

4.算法

5.时间复杂度

6.空间复杂度

7.数据类型

8.抽象数据类型

9.线性表

10.循环链表

11.双向链表

12.静态链表

13.栈

14.循环队列

15.队列

16.串

17.子串

18.广义表

19.二叉树

20.满二叉树

21.中序遍历

22.线索

23.线索化

24.先序遍历

25.后序遍历

26.水平遍历

27.树的深度

28.树的度

29.树

30.完全二叉树

31.前缀码

32.哈夫曼编码

33.最优二叉树

34.最小生成树

35.完全有向图

36.完全无向图

37.广度遍历

38.深度遍历

39.生成树

40.生成森林

41.环(简单环)

42.路径

43.极大连通子图

44.连通图

45.拓扑排序

46.关键路径

47.最短路径

48.折半查找

49.索引顺序表

50.二叉排序树

51.平衡因子

52.平衡二叉树

53.平衡旋转

54.LR型平衡旋转

55.LL型平衡旋转

56.RL型平衡旋转

57.RR型平衡旋转

58.哈希函数

59.哈希表

60.shell排序

61.气泡排序法

62.选择排序

63.快速排序

64.堆排序

65.交换排序

66.插入排序

67.稳定排序

68.不稳定排序

69.内部排序

70.归并排序

71.基数排序

72.外部排序

五.简答

1、什么是数据,数据元素、数据项?

何谓主关键字?

2、什么是数据结构?

什么是存储结构?

它们各有多少种形式?

3、衡量一个算法性能好坏的标准是什么?

5、如果两个算法的平均时间复杂度相同,能否说,这两个算法的实际执行时间一定相等?

6、试描述数据结构的概念与程序设计语言中数据类型概念的区别。

1、什么是数据结构?

2、数据结构是如何分类的?

举出你所学的六种并分类。

3、衡量一个算法性能好坏的标准是什么?

4、抽象数据类型如何描述,以线性表为例说明。

5、描述以下三个概念的区别:

哨兵指针,哨兵结点,首结点(第一个元素结点)。

6、算法与程序的主要区别是什么?

7、如果两个算法的平均时间复杂度相同,能否说,这两个算法的实际执行时间一定相等?

(不一定)。

8、线性表、栈、队列的区别与联系。

9、线性表的顺序存储结构与链式存储结构在操作上的

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

当前位置:首页 > 小学教育 > 英语

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

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