数据结构练习题5 图
数据结构练习(附答案)
习题一绪论.1.1 单项选择题1. 数据结构是一门研究非数值计算的程序设计问题中计算机的① A 以及它们之间的② B 和运算等的学科。
①A.操作对象B.计算方法C.逻辑存储D.数据映象②A.结构B.关系C.运算D.算法2. 数据结构被形式地定义为(K,R),其中K是① B 的有限集合,R是K上的②D 有限集合。
①A.算法B.数据元素C.数据操作D.逻辑结构②A.操作B.映象C.存储D.关系3. 在数据结构中,从逻辑上可以把数据结构分成 C 。
A.动态结构和静态结构B.紧凑结构和非紧凑结构C.线性结构和非线性结构D.内部结构和外部结构4. 线性表的顺序存储结构是一种① A 的存储结构,线性表的链式存储结构是一种② B 的存储结构。
A.随机存取B.顺序存取C.索引存取D.散列存取5. 算法分析的目的是① C ,算法分析的两个主要方面是② A B 。
① A. 找出数据结构的合理性 B. 研究算法中的输入和输出的关系C. 分析算法的效率以求改进D. 分析算法的易懂性和文档性② A. 空间复杂性和时间复杂性 B. 正确性和简明性C. 可读性和文档性D. 数据复杂性和程序复杂性6. 计算机算法指的是① C ,它必具备输入、输出和② B 等五个特性。
①A. 计算方法 B. 排序方法C. 解决问题的有限运算序列D. 调度方法②A. 可行性、可移植性和可扩充性 B. 可行性、确定性和有穷性C. 确定性、有穷性和稳定性D. 易读性、稳定性和安全性7. 线性表的逻辑顺序与存储顺序总是一致的,这种说法 B 。
A. 正确B. 不正确8. 线性表若采用链式存储结构时,要求内存中可用存储单元的地址 D 。
A. 必须是连续的B. 部分地址必须是连续的C. 一定是不连续的D. 连续或不连续都可以9. 在以下的叙述中,正确的是 B 。
A.线性表的线性存储结构优于链表存储结构B.二维数组是其数据元素为线性表的线性表C.栈的操作方式是先进先出D.队列的操作方式和先进后出10. 每种数据结构都具备三个基本运算:插入、删除和查找,这种说法 B 。
数据结构习题
图习题(三)
• 1.如图所示是一个无向网图,请分别按Prim 算法和Kruskal算法求最小生成树。
查找习题(一)
1.已知一个有序表为(12,18,24,35,47,50,62,83,90,115,134), 当折半查找值为 90 的元 素时,经过( )次比较后查找成功。 A2 B3 C4 D5 2.已知 10 个元素(54,28,16,73,62,95,60,26,43),按照依次插入 的方法生成一棵二叉排序树,查找值为 62 的结点所需比较次数为( )。 A2 B3 C4 D5 3.已知数据元素为(34,76,45,18,26,54,92,65),按照依次插入结点 的方法生成一棵二叉排序树,则该树的深度为( )。 A4 B5 C6 D7 4.按( )遍历二叉排序树得到的序列是一个有序序列。 A 前序 B 中序 C 后序 D 层次 5.在散列函数 H(k)= k mod m 中,一般来讲,m 应取( )。 A 奇数 B 偶数 C 素数 D 充分大的数
8.设链栈中结点的结构:data为数据域,next为指针域,且top是栈顶指针。若想 在链栈的栈顶插入一个由指针s所指的结点,则应执行下列( )操作。 A.s->next=top->next;top->next=s; B.top->next=s; C.s->next=top;top=top->next; D.s->next=top;top=s;
D.根据元素查找
线性表习题(二)
1.链表相对于顺序表的优点是: 插入、删除 方便。 2.顺序表中访问任意一个结点的时间复杂度均为 O(1) 。 3.在单链表中要在已知结点*P之前插入一个新结点,需找到 *P的直接前趋结点的地址,其查找的时间复杂度为 O(n) 。 4.单链表中需知道 头指针 才能遍历整个链表。 5.在一个长度为n的顺序表中删除第i个元素,要移动 n-i 个元 素。 6.在一个长度为n的顺序表中,如果要在第i个元素前插入一 个元素,要后移 n-i+1 个元素。 7.双链表中,设p是指向其中待删除的结点,则需要执行的操 作为: p->prior->next=p->next 。
数据结构练习题
已知L是无表头结点的单链表,且P结点既 不是首元结点也不是尾结点,给出: 1.在P结点后插入S结点的语句序列: 2.在P结点前插入S结点的语句序列: 3.在表首插入S结点的语句序列: 4.在表尾插入S结点的语句序列:
已知L是带表头结点的非空单链表,且P结点 既不是首元结点也不是元尾结点,给出: 1.删除P结点的直接后继结点的语句序列: 2.删除P结点的直接前驱结点的语句序列: 3.删除P结点的语句序列: 4删除首元结点的语句序列 : 5.删除尾元结点的语句序列 :
• 一棵含有n个结点的k叉树,可能达到的 最大深度和最小深度各为多少? • 证明:一棵满k叉树上的叶子结点数n0和 非叶子结点数n1,满足以下关系 n0=(k-1)n1+1 • 找出所有满足下列条件的二叉树: 1.先序遍历和中序遍历的序列相同 2.后序遍历和中序遍历的序列相同 3.先序遍历和后序遍历的序列相同 • 对图中的树进行后序线索化
• 简述以下算法的功能 1.status A(linkdList L)//L是无表头结点的单链表 {if(L&&L->next) {Q=L;L=L->next;P=L; while(P->next)P=P->next; P->next=Q;Q->next=NULL; } return OK; }
• 2.void BB(Lnode *s, Lnode * q) {p=s; while(p->next!=q)p=p->next; p->next=s; } Void AA(Lnode *pa, Lnode *pb) {BB(pa,pb); BB(pb,pa); }
• 对以下单链表分别执行下例各程序段,给出结果示意 图 1.Q=P->next; 2.L=P->next; 3. R->data=P->data; 4. R->data=P->next->data; 5.P->next->next->next->data=P->data; 6.T=P; While(T!=NULL){T->data=T->data*2;T=T->next;} 7. T=P; While(T->next!=NULL){T->data=T->data*2;T=T->next;}
数据结构练习题及答案
数据结构练习题(一)一、单选题1.栈和队列的共同特点是( )。
A.只允许在端点处插入和删除元素B.都是先进后出C.都是先进先出D.没有共同点2.用链接方式存储的队列,在进行插入运算时( )。
A. 仅修改头指针B. 头、尾指针都要修改C. 仅修改尾指针D.头、尾指针可能都要修改3.以下数据结构中( )是非线性结构。
A. 队列B. 栈C. 线性表D. 二叉树4.设有一个二维数组A[m][n],假设A[0][0]存放位置在644(10),A[2][2]存放位置在676(10),每个元素占一个空间,问A[3][3](10)存放在()位置。
脚注(10)表示用10进制表示。
A.688 B.678 C.692 D.6965.树最适合用来表示( )。
A.有序数据元素B.无序数据元素C.元素之间具有分支层次关系的数据D.元素之间无联系的数据6.二叉树的第k层的结点数最多为( )。
A.2k-1 +1 D. 2k-17.若有18个元素的有序表存放在一维数组A[19]中,第一个元素放A[1]中,现进行二分查找,则查找A[3]的比较序列的下标依次为( )。
A. 1,2,3B. 9,5,2,3C. 9,5,3D. 9,4,2,38.对于线性表(7,34,55,25,64,46,20,10)进行散列存储时,若选用H(K)=K %9作为散列函数,则散列地址为1的元素有()个。
A.1 B.2 C.3 D.49.设有6个结点的无向图,该图至少应有( )条边才能确保是一个连通图。
二、填空题1.通常从四个方面评价算法的质量:_________、_________、_________和_________。
2.一个算法的时间复杂度为(n3+n2log2n+14n)/n2,其数量级表示为________。
3.假定一棵树的广义表表示为A(C,D(E,F,G),H(I,J)),则树中所含的结点数为__________个,树的深度为___________,树的度为_________。
数据结构 图 练习题
数据结构图练习题数据结构图练习题在计算机科学领域中,数据结构是一种用来组织和存储数据的方式。
而图是一种常见的数据结构,它由一组节点和连接这些节点的边组成。
图可以用来表示各种各样的关系,比如社交网络中的用户关系、城市之间的道路网络等等。
在本文中,我们将探讨一些与图相关的练习题,帮助读者更好地理解和应用图的概念。
1. 最短路径问题最短路径问题是图论中的经典问题之一。
给定一个带权重的有向图,我们需要找到从一个起始节点到目标节点的最短路径。
这里的权重可以表示为距离、时间或者其他度量。
解决这个问题的算法有很多,其中最著名的是Dijkstra算法和Bellman-Ford算法。
读者可以尝试使用这些算法来解决一些具体的实例,比如计算两个城市之间的最短路径。
2. 拓扑排序拓扑排序是对有向无环图(Directed Acyclic Graph,简称DAG)进行排序的一种算法。
在一个DAG中,节点之间存在一种偏序关系,即某些节点必须在其他节点之前进行处理。
拓扑排序可以帮助我们确定这种偏序关系,从而找到一种合理的处理顺序。
比如,在编译器中,拓扑排序可以用来确定源代码中各个函数的调用顺序。
读者可以尝试编写一个拓扑排序算法,并应用到一些具体的场景中。
3. 最小生成树最小生成树是一个无向连通图中一棵权值最小的生成树。
在一个连通图中,最小生成树可以帮助我们找到一种最优的连接方式,以满足一些约束条件。
最常用的算法是Prim算法和Kruskal算法。
读者可以尝试使用这些算法来解决一些具体的实例,比如在一个城市之间建设光纤网络,以最小的成本实现全覆盖。
4. 图的遍历图的遍历是指按照某种方式访问图中的所有节点。
常见的遍历算法有深度优先搜索(DFS)和广度优先搜索(BFS)。
DFS通过递归地访问每个节点的邻居节点,直到所有节点都被访问完。
BFS则通过队列来实现,先访问起始节点的邻居节点,然后依次访问它们的邻居节点,直到所有节点都被访问完。
数据结构练习题及参考答案
《数据结构》练习题一、解答题(共50分)1、(8分)假设用于通讯的电文字符集及其出现的频率如下表所示。
请为这8个字符设计哈夫曼编码,并画出其哈夫曼树,计算WPL 。
2. (8分)若一棵二叉树中序遍历和后序遍历序列分别为:DBEHGAFIC 和DHGEBIFCA 。
试画出这棵二叉树,并写出其先序遍历和层序遍历序列。
3.(16分)以下无向网络以邻接表为存储结构(假设邻接表的顶点表按字母a 、b 、c 、d 、e 、f 、g 、h 的顺序依次存储,邻接表的边表结点按顶点的下标由小到大链接)。
请画出其邻接表,并写出从顶点f 出发,分别进行深度和广度优先遍历的序列,写出用Prime 方法从顶点c开始产生最小生成树的边的序列。
4.(8分)已知键值序列为(44,39,67,25, 52,59,43,84,54,58,15,26,12,73,92,69),取填充因子α=0.8,采用线性探查法处理冲突,试构造散列表。
⒌(5分)已知一组记录为(67,88,15,12,60,37,7,31,45,81),用希尔排序方法进行排序,d1=5,d2=3,d3=1,则第二趟的排序结果是( )。
⒍(5分)已知一组记录为(67,88,15,12,60,37,7,31,45,81) ,用堆(大根堆)排序方法进行排序,第一趟的排序结果是( )。
二、完善程序(共20分,每空2分)1.假设一组递减有序的原始数据存储在数组r 中,存放元素的下标下限为low,下标上字符 出现频率 a 0.05 b 0.03 c 0.24 d 0.16 e 0.08 f 0.24 g 0.18 h0.02限为high,以下是在数组中查找数值为k的折半查找算法。
请填空完善程序。
int BinSearch(int r[ ], int low,int high,int k){ int l,h,m;l= low; h= high;while ( ⑴){m= ⑵;if (k < r[m]) ⑶;else if (k > r[m]) ⑷;else return m;}return 0;}2. 以下程序功能是将数组r中,从下标first到end之间的元素进行快速排序的分区。
数据结构习题(有答案)
{ for ( j=i; j<length; j++) // ai至an依次前移
Elem[j-1] = elem[j];
length - - ; //表长减一
return 1 ; //删除成功,返回1
}
return 0 ; //未找到,删除不成功,返回0
要求:给出问题分析、算法描述、源程序及运行截图,在线提交。
1.设a, b, c为3个整数,求其中位于中间值的整数。
1.设计算法:在顺序表中删除值为e的元素,删除成功,返回1;否则,返回0。
int Sqlist<T>::DeleteElem( T e )
{ for (i=1; i<=length; i++) //按值顺序查找* i可从0开始
(2)借助栈T,将栈S中所有值为e的数据元素删除之。
3.编写一个算法,将一个非负的十进制整数N转换为B进制数,并输出转换后的结果。当N=248D,B分别为8和16时,转换后的结果为多少?
#include“stack.h”
int NumTrans( int N, int B) {//十进制整数N转换为B进制数
if ( head==NULL) throw“表空!”; //空表,不能删
else if ( i==1) { //删除第1个元素
p=Head; x=p->data; //保存被删元素值
Head= p->next ;
delete p ;
}
else { //元素定位到第ai-1
p=Head; j=1 ; //定位查找起始位置
{ int p=1;
数据结构(图)习题与答案
一、单选题1、设有5个结点的无向图,该图至少应有_________条边才能确保是一个连通图。
A.7B.8C.6D.5正确答案:A2、设图G=(V,VR),其中: V={A,B,C,D,G},VR={(A,C),(A,D),( B,C),(B,D) ,(G,C),(B,G)},则对应的图形为_________。
A.B.C.D.正确答案:C3、设某有向图中有n个顶点,则该有向图对应的邻接表中有_________个表头结点。
A.n-1B.n+2C.nD.n+1正确答案:C4、在一个无向图中所有顶点的度数之和等于所有边数的_________倍。
A.1B.2C.3D.1/2正确答案:B5、一个无向连通图的生成树是该连通图的_____。
A.极小连通子图B.强连通子图C.连通子图D.极大连通子图正确答案:A6、设某无向图中有n个顶点,则该无向图邻接矩阵的大小是_________。
A.n(n+1)/2B.(n-1)2C. n2D. (n+1)2正确答案:C7、设有n个顶点e条边的无向图,采用邻接矩阵作为物理结构,则删除与某顶点Vi 关联的所有边算法的时间复杂度为_________。
A.O(n2)B.O(n+e)C.O(n*e)正确答案:D8、设有n个顶点e条弧的有向图,采用邻接表作为物理结构,则求某顶点Vi度的算法的时间复杂度为_________。
A.O(n)B.O(n*e)C.O(n+e)D.O(n2)正确答案:C9、设无向图G=(V,E)和G'=(V',E'),如果G'是G的生成树,则下列说法中错误的是_____。
A.G'是G的连通分量B.G'是G的一个无环子图C.G'是G的极小连通子图且V=V'D.G'是G的子图正确答案:A10、设G是一个非连通的无向图,共有10条边,则该图至少有_____个顶点。
A.7B.6C.5D.8正确答案:B11、 n个顶点的有向图为强连通图时,至少含有________。
数据结构练习试题和答案解析
数据结构练习试题和答案解析第1章绪论判断题数据的逻辑结构与数据元素本⾝的内容和形式⽆关。
(V )⼀个数据结构是由⼀个逻辑结构和这个逻辑结构上的⼀个基本运算集构成的整体。
(V )数据元素是数据的最⼩单位。
(X )数据的逻辑结构和数据的存储结构是相同的。
(X )程序和算法原则上没有区别,所以在讨论数据结构时可以通⽤。
(X )从逻辑关系上讲,数据结构主要分为线性结构和⾮线性结构两类。
(V )数据的存储结构是数据的逻辑结构的存储映象。
(V )数据的物理结构是指数据在计算机内实际的存储形式。
(V )数据的逻辑结构是依赖于计算机的。
(X )算法是对解题⽅法和步骤的描述。
(V )填空题数据有逻辑结构和存储结构两种结构。
数据逻辑结构除了集合以外,还包括线性结构、树形结构和图形结⽊。
数据结构按逻辑结构可分为两⼤类,它们是线性结构和⾮线性 ____ 。
树形结构和图形结构合称为⾮线性结构。
在树形结构中,除了树根结点以外,其余每个结点只有 1个前驱结点。
在图形结构中,每个结点的前驱结点数和后继结点数可以任意多 _ 。
数据的存储结构⼜叫物理结构。
数据的存储结构形式包括顺序存储、链式存储、索引存储和散列存 ___ 。
线性结构中的元素之间存在⼀只的关系。
树形结构中的元素之间存在⼀只的关系。
图形结构的元素之间存在多对多的关系。
数据结构主要研究数据的逻辑结构、存储结构和算法(或运算) 3个⽅⾯的内容。
数据结构被定义为(D, R ),其中D 是数据的有限集合, R 是D 上的关系有限集合。
算法是⼀个有穷指令的集合。
算法效率的度量可以分为事先估算法和事后 ______ 。
⼀个算法的时间复杂度是算法输⼊规模的函数。
算法的空间复杂度是指该算法所耗费的存储空间,它是该算法求解问题规模的 n 的函数。
若⼀个算法中的语句频度之和为 T (n )=6n+3nlog 2n,则算法的时间复杂度为 0 ( nlog 2n )若⼀个算法的语句频度之和为T (n )=3n+nlog 2+n 2,则算法的时间复杂度为 0(n 2)。
数据结构练习题1-5章(答案)
11、 一个栈的输入序列为 123…n,若输出序列的第一个元素是 n,输出第 i(1<=i<=n)个元
素是( B )。
A. 不确定
B. n-i+1
C. i
D. n-i
1
12、 有六个元素 6,5,4,3,2,1 的顺序进栈,问下列哪一个不是合法的出栈序列?( C )
A. 5 4 3 6 1 2 B. 4 5 3 1 2 6 C. 3 4 6 5 2 1 D. 2 3 4 1 5 6
A. 1 和 5
B. 2 和 4
C. 4 和 2
D. 5 和 1
16、下面关于串的的叙述中,哪一个是不正确的?( B )
A.串是字符的有限序列
B.空串是由空格构成的串
C.模式匹配是串的一种重要运算 D.串既可以采用顺序存储,也可以采用链式存储
17、设有两个串 p 和 q,其中 q 是 p 的子串,求 q 在 p 中首次出现的位置的算法称为( c )
A. 内存地址
B.数组下标 C.下一元素地址
D.左、右孩子地址
7、下面的叙述不正确的是( BC )
A.线性表在链式存储时,查找第 i 个元素的时间同 i 的值成正比
B. 线性表在链式存储时,查找第 i 个元素的时间同 i 的值无关
C. 线性表在顺序存储时,查找第 i 个元素的时间同 i 的值成正比
D. 线性表在顺序存储时,查找第 i 个元素的时间同 i 的值无关
13、 设有三个元素 X,Y,Z 顺序进栈(进的过程中允许出栈),下列得不到的出栈排列是( C )。
A.XYZ
B. YZX
C. ZXY
D. ZYX
14、 假设以数组 A[m]存放循环队列的元素,其头尾指针分别为 front 和 rear,则当前队列中的
《数据结构》 关于概论的练习题(PPT内含答案)
一、选择题
1.数据结构通常是研究数据的( A )及它们之间的相互联 系。
A.存储结构和逻辑结构 B.存储和抽象
C.联系和抽象
D.联系与逻辑
2.从逻辑上可以把数据结构分为( C )两大类。
A.动态结构、静态结构 B.顺序结构、链式结构
C.线性结构、非线性结构 D.初等结构、构造型结构
3.数据处理的基本单位是( A )。
A.物理结构
B.存储结构
C.逻辑结构
D.逻辑和存储结构
17.下列四种基本逻辑结构中,数据元素之间关系最弱的是 ( A )。
A.集合 B.线性结构 C.树形结构 D.图形结构
18.与数据元素本身的形式、内容、相对位置、个数无关的 是数据的( A )。
A.逻辑结构 B.存储结构 C.逻辑实现 D.存储实现
B.可读性和文档性
C.数据复杂性和程序复杂性 杂度
D.时间复杂度和空间复
11.算法的计算量大小称为算法的( C )。
A.现实性 B.难度 C.时间复杂性 D.效率
12.数据的基本单位是( B )。
A.数据结构 B.数据元素 C.数据项 D.文件
13.每个结点只含有一个数据元素,所有存储结点相继存放 在一个连续的存储区里,这种存储结构称为( A )结构。
C.多对多
D.无关系
习题1
7.数据在计算机存储器内表示时,物理地址和逻辑地址相 同并且是连续的,称为( C )。
A.存储结构
B.逻辑结构
C.顺序存储结构 D.链式存储结构
8.非线性结构中的每个结点( D )。
A.无直接前趋结点 B.无直接后继结点
C.只有一个直接前趋结点和一个直接后继结点
D.可能有多个直接前趋结点和多个直接后继结点
数据结构图练习题(附答案).doc
第七章 图一、选择题1.图中有关路径的定义是( )。
【北方交通大学 2001 一、24 (2分)】A .由顶点和相邻顶点序偶构成的边所形成的序列B .由不同顶点所形成的序列C .由不同边所形成的序列D .上述定义都不是2.设无向图的顶点个数为n ,则该图最多有( )条边。
A .n-1B .n(n-1)/2C . n(n+1)/2D .0E .n 2【清华大学 1998 一、5 (2分)】【西安电子科技大 1998 一、6 (2分)】【北京航空航天大学 1999 一、7 (2分)】3.一个n 个顶点的连通无向图,其边的个数至少为( )。
【浙江大学 1999 四、4 (4分)】A .n-1B .nC .n+1D .nlogn ;4.要连通具有n 个顶点的有向图,至少需要( )条边。
【北京航空航天大学 2000 一、6(2分)】A .n-lB .nC .n+lD .2n5.n 个结点的完全有向图含有边的数目( )。
【中山大学 1998 二、9 (2分)】A .n*n B.n (n +1) C .n /2 D .n*(n -l )6.一个有n 个结点的图,最少有( )个连通分量,最多有( )个连通分量。
A .0B .1C .n-1D .n【北京邮电大学 2000 二、5 (20/8分)】7.在一个无向图中,所有顶点的度数之和等于所有边数( )倍,在一个有向图中,所有顶点的入度之和等于所有顶点出度之和的( )倍。
【哈尔滨工业大学 2001 二、3 (2分)】A .1/2B .2C .1D .48.用有向无环图描述表达式(A+B)*((A+B )/A ),至少需要顶点的数目为( )。
【中山大学1999一、14】A .5B .6C .8D .99.用DFS 遍历一个无环有向图,并在DFS 算法退栈返回时打印相应的顶点,则输出的顶点序列是( )。
A .逆拓扑有序B .拓扑有序C .无序的 【中科院软件所1998】10.下面结构中最适于表示稀疏无向图的是( ),适于表示稀疏有向图的是( )。
数据结构习题五(答案)
数据结构习题(5)学号________ 姓名_______ 课堂号(___________)1.选择题1)对N个元素的表做顺序查找时,若查找每个元素的概率相同,则平均查找长度为( A )A.(N+1)/2 B. N/2 C. N D. [(1+N)*N ]/22)下面关于二分查找的叙述正确的是 ( D )A. 表必须有序,表可以顺序方式存储,也可以链表方式存储B. 表必须有序且表中数据必须是整型,实型或字符型C. 表必须有序,而且只能从小到大排列D. 表必须有序,且表只能以顺序方式存储3)折半查找的时间复杂性为(D)A. O(n2)B. O(n)C. O(nlog(n))D. O(log(n))4)概率不同的有序表,最适合的查找算法是( C )A.顺序查找B.折半查找C.静态树表查找 D.索引顺序表查找5)平均查找长度最短的查找方法是____C________。
A.折半查找 B.顺序查找 C.哈希查找 4.其他6)折半查找有序表(4,6,10,12,20,30,50,70,88,100)。
若查找表中元素58,则它将依次与表中A比较大小,查找结果是失败。
A.20,70,30,50 B.30,88,70,50 C.20,50 D.30,88,507)当采用分快查找时,数据的组织方式为 ( B )A.数据分成若干块,每块内数据有序B.数据分成若干块,每块内数据不必有序,但块间必须有序,每块内最大(或最小)的数据组成索引块C. 数据分成若干块,每块内数据有序,每块内最大(或最小)的数据组成索引块D. 数据分成若干块,每块(除最后一块外)中数据个数需相同8)分别以下列序列构造二叉排序树,与用其它三个序列所构造的结果不同的是( C )A.(100,80, 90, 60, 120,110,130) B.(100,120,110,130,80, 60, 90)C.(100,60, 80, 90, 120,110,130)D. (100,80, 60, 90, 120,130,110)9)设有一组记录的关键字为{19,14,23,1,68,20,84,27,55,11,10,79},用链地址法构造散列表,散列函数为H(key)=key MOD 13,散列地址为1的链中有( D )个记录。
数据结构习题(1-5章)
第一章绪论一、填空题1、数据结构是一门研究非数值计算的程序设计问题中计算机的操作对象以及它们之间的关系和运算等的学科。
2、数据结构被形式地定义为(D, R),其中D是数据元素的有限集合,R是D上的关系有限集合。
3、数据结构包括数据的逻辑结构、数据的存储结构和数据的运算这三个方面的内容。
4、数据结构按逻辑结构可分为两大类,它们分别是线性结构和非线性结构。
5、线性结构中元素之间存在一对一关系,树形结构中元素之间存在一对多关系,图形结构中元素之间存在多对多关系。
6、在线性结构中,第一个结点没有前驱结点,其余每个结点有且只有1个前驱结点;最后一个结点没有后续结点,其余每个结点有且只有1个后续结点。
7、在树形结构中,树根结点没有前驱结点,其余每个结点有且只有1个前驱结点;叶子结点没有后续结点,其余每个结点的后续结点数可以任意多个。
8、在图形结构中,每个结点的前驱结点数和后续结点数可以任意多个。
9、数据的存储结构可用四种基本的存储方法表示,它们分别是顺序、链式、索引和散列。
10、数据的运算最常用的有5种,它们分别是插入、删除、修改、查找、排序。
11、一个算法的效率可分为时间效率和空间效率。
二、单项选择题(B)1、非线性结构是数据元素之间存在一种:A)一对多关系B)多对多关系C)多对一关系D)一对一关系( C )2、数据结构中,与所使用的计算机无关的是数据的结构;A) 存储B) 物理C) 逻辑D) 物理和存储(C)3、算法分析的目的是:A) 找出数据结构的合理性B) 研究算法中的输入和输出的关系C) 分析算法的效率以求改进D) 分析算法的易懂性和文档性(A)4、算法分析的两个主要方面是:A) 空间复杂性和时间复杂性B) 正确性和简明性C) 可读性和文档性D) 数据复杂性和程序复杂性( C )5、计算机算法指的是:A) 计算方法B) 排序方法C) 解决问题的有限运算序列D) 调度方法(B)6、计算机算法必须具备输入、输出和等5个特性。
数据结构练习题5
数据结构练习题习题5 数组和广义表一、基本内容数组定义及表示方式;特殊矩阵和稀疏矩阵的压缩存储方法及运算的实现;广义表的逻辑结构和存储结构。
二、学习要点1.了解数组的两种存储表示方法,并掌握数组在以行为主的存储结构中的地址计算方法。
2.掌握对特殊矩阵进行压缩存储时的下标变换公式。
3.了解稀疏矩阵的两种压缩存储方法的特点和适用范围,领会以三元组表示稀疏矩阵时进行矩阵运算采用的处理方法。
4.掌握广义表的结构特点及其存储表示方法,读者可根据自己的习惯掌握任意一种结构的链表5.1 单项选择题1. 常对数组进行的两种基本操作是____。
A. 建立与删除B. 索引和修改查找与索引2. 二维数组M的成员是6个字符(每个字符占一个存储单元,即一个字节)组成的串,行下标i的范围从0到8,列下标j的范围从0到9,则存放M 至少需要①_ _个字节;M数组的第8列和第5行共占②____个字节。
①3. 二维数组A中,每个元素的长度为3个字节,行下标i从0到7,列下标j从0到9,从首地址SA开始连续存放在存储器内,存放该数组至少需要的字节数是____。
4. 二维数组A中,每个元素A的长度为3个字节,行下标i从0到7,列下标j从0到9,从首地址SA开始连续存放在存储器内,该数组按行存放时,数组元素A[7][4]的起始地址为____。
5. 二维数组A中,每个元素A的长度为3个字节,行下标i从0到7,列下标j从0到9,从首地址SA开始连续存放在存储器内,该数组按列存放时,元素A[4][7]的起始地址为____。
5.21. 已知二维数组A[m][n]采用行序为主方式存储,每个元素占k个存储单元,并且第一个元素的存储地址是LOC(A[0][0]),则A[i][j]的地址是__ LOC (A[0][0])+(n*i+j)*k __。
2. 二维数组A[10][20]采用列序为主方式存储,每个元素占一个存储单元并且A[0][0]的存储地址是200,则A[6][12]的地址是__ 200+(12*10+6)= 326_。
数据结构习题(含答案)
一、单选题(每小题3分,共30分)1.在逻辑上可以把数据结构分成。
( ) A.动态结构和静态结构B.紧凑结构和非紧凑结构C.线性结构和非线性结构D.内部结构和外部结构2.串是_________。
( ) A.不少于一个字母的序列B.任意个字母的序列C.不少于一个字符的序列D.有限个字符的序列3.在n个元素的顺序表中,时间复杂度是O(1)的操作是______。
( ) A.获得第i个数据元素值B.查找给定值C.在第i个位置上插入数据元素D.删除第i个数据元素4.线性表若采用链式存储结构时,要求内存中可用存储单元的地址________。
( )A. 必须是连续的B. 部分地址必须是连续的C. 一定是不连续的D. 连续或不连续都可以5.单链表中,在p结点之后插入q结点,操作的语句为。
( ) A.q->next=p->next,p->next=q B.p=q->next,q->next=pC.p->next=q->next,q->next=p D.q=p->next,p->next=q6.栈中数据元素的插入和删除操作是在表的进行的。
( )A.一端B.两端C.中间D.任意位置7.队列的特点是。
( )A.先进先出B.后进先出C.先进后出D.随机存取8.树中结点A有3个兄弟,结点B是A的双亲,则B的度是。
( )A.1B.2C.3D.49.下面关于图的存储结构的叙述中正确的是____________。
( )A.用邻接矩阵存储图,占用空间大小只与图中顶点数有关,而与边数无关B.用邻接矩阵存储图,占用空间大小只与图中边数有关,而与顶点数无关C.用邻接表存储图,占用空间大小只与图中顶点数有关,而与边数无关D.用邻接表存储图,占用空间大小只与图中边数有关,而与顶点数无关10.对于不带权的有向图,其邻接矩阵的每一列包含的“1”的个数为。
( )A.图中每个顶点的入度B.图中每个顶点的出度C.图中弧的条数D.图中连通分量的数目二、判断题(每小题1分,共10分)对于正确的说法,请在题前的括号内打√,错误的说法则打×。
数据结构第五章图习题
05 图【单选题】1. 设无向图G 中有五个顶点,各顶点的度分别为2、4、3、1、2,则G 中边数为(C )。
A、4条 B、5条 C、6条 D、无法确定2. 含n 个顶点的无向完全图有(D )条边;含n 个顶点的有向图最多有(C )条弧;含n 个顶点的有向强连通图最多有(C )条弧;含n 个顶点的有向强连通图最少有(F)条弧;设无向图中有n 个顶点,则要接通全部顶点至少需(G )条边。
A 、n 2B 、n(n+1)C 、n(n-1)D 、n(n-1)/2E 、n+1F 、nG 、n-13. 对下图从顶点a 出发进行深度优先遍历,则(A )是可能得到的遍历序列。
A 、acfgdebB 、abcdefgC 、acdgbefD 、abefgcd对下图从顶点a 出发进行广度优先遍历,则(D )是不可能得到的遍历序列。
A 、abcdefgB 、acdbfgeC 、abdcegfD 、adcbgef4. 设图G 的邻接矩阵A=⎥⎥⎥⎦⎤⎢⎢⎢⎣⎡010101010,则G 中共有(C )个顶点;若G 为有向图,则G 中共有(D )条弧;若G 为无向图,则G 中共有(B )条边。
A 、1B 、2C 、3D 、4E 、5F 、9G 、以上答案都不对5. 含n个顶点的图,最少有(B)个连通分量,最多有(D)个连通分量。
A、0B、1C、n-1D、n6. 用邻接表存储图所用的空间大小(A)。
A、与图的顶点数和边数都有关B、只与图的边数有关C、只与图的顶点数有关D、与边数的平方有关7. n个顶点的无向图的邻接表最多有(B)个表结点。
A、n2B、n(n-1)C、n(n+1)D、n(n-1)/28. 无向图G=(V,E),其中:V={a,b,c,d,e,f},E={(a,b),(a,e),(a,c),(b,e),(c,f),(f,d),(e,d)},对该图进行深度优先遍历,得到的顶点序列正确的是(D)。
A、a,b,e,c,d,fB、a,c,f,e,b,dC、a,e,b,c,f,dD、a,e,d,f,c,b9. 图的BFS生成树的树高比DFS生成树的树高(A)。
数据结构(本科)期末综合练习五(算法设计题)
数据结构(本科)期末综合练习五(算法设计题)1. 设有一个线性表 (e0, e1, …, e n-2, e n-1) 存放在一个一维数组A[arraySize]中的前n个数组元素位置。
请编写一个函数将这个线性表原地逆置,即将数组的前n个元素内容置换为 (e n-1, e n-2, …, e1, e0)。
函数的原型为:template<class Type>void inverse ( Type A[ ], int n );2. 试编写一个函数,在一个顺序表A中找出具有最大值和最小值的整数。
函数的原型如下所示,原型的参数表中给出顺序表对象为A,通过算法执行,从参数表中的引用参数Max中得到表中的最大整数,Min中得到表中的最小整数。
注意,函数中可使用顺序表的两个公有函数:Length( ) 求表的长度;getData(int k) 提取第k个元素的值。
#include “SeqList.h”template <class T> void FindMaxMin ( SeqList<int>& A, int& Max, int& Min );3. 设有两个整数类型的顺序表A(有 m个元素)和B(有n个元素),其元素均以升序排列。
试编写一个函数,将这两个顺序表合并成一个顺序表C,要求C的元素也以升序排列(表中允许元素重复)。
函数的原型如下所示。
原型中的参数表给出参加运算的三个顺序表A、B与C。
从C中得到执行结果。
函数中用到顺序表的4个公有函数:Length( ) 求表的当前长度;maxLength( ) 求表的最大允许长度;getData(int k) 提取第k个元素的值;setData(int k, int val) 修改第k个元素的值为val。
template<class T>void merge(SeqList<int>& A, SeqList<int>& B, SeqList<int>& C);4. 编写一个函数frequency,统计在一个输入字符串中各个不同字符出现的频度。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
补充习题5 图
5.1 单项选择题
1.在一个图中,所有顶点的度数之和等于所有边数的____倍。
A. 1/2
B. 1
C. 2
D. 4
2.任何一个无向连通图的最小生成树。
A.只有一棵
B.有一棵或多棵
C.一定有多棵
D.可能不存在
3.在一个有向图中,所有顶点的入度之和等于出度之和的____倍。
A. 1/2
B. 1
C. 2
D. 4
4.一个有n个顶点的无向图最多有____条边。
A. n
B. n(n-1)
C. n(n-1)/2
D. 2n
5.具有4个顶点的无向完全图有____条边。
A. 6
B. 12
C. 16
D. 20
6.具有6个顶点的无向图至少应有____条边才能确保是一个连通图。
A. 5
B. 6
C. 7
D. 8
7.在一个具有n个顶点的无向图中,要连通全部顶点至少需要____条边。
A. n
B. n+1
C. n-1
D. n/2
8.一个具有n个顶点的无向图,若采用邻接矩阵表示,则矩阵的大小是____。
A. n
B. (n-1)2
C. n-1
D. n2
9.对于一个具有n个顶点和e条边的无向图,若采用邻接表表示,则表头向量的大小为_①___;所有邻接表中的结点总数是__②__。
① A. n B. n+1 C. n-1 D. n+e
② A. e/2 B. e C.2e D. n+e
10.已知一个图如图5.1所示,若从顶点a出发按深度搜索法进行遍历,则可能得到的一种顶点序列为__①__;按宽度搜索法进行遍历,则可能得到的一种顶点序列为__②__。
① A. a,b,e,c,d,f B. e,c,f,e,b,d C. a,e,b,c,f,d D. a,e,d,f,c,b
C. a,e,b,c,f,d
D. a,c,f,d,e,b
②
11.已知一有向图的邻接表存储结构如图5.2所示。
⑴ 根据有向图的深度优先遍历算法,从顶点v1出发,所得到的顶点序列是____。
A. v1,v2,v3,v5,v4
B. v1,v2,v3,v4,v5
C. v1,v3,v4,v5,v2
D. v1,v4,v3,v5,v2 ⑵ 根据有向图的宽度优先遍历算法,从顶点v1出发,所得到的顶点序列是____。
A. v1,v2,v3,v4,v5
B. v1,v3,v2,v4,v5
C. v1,v2,v3,v5,v4
D. v1,v4,v3,v5,v2
12.采用邻接表存储的图的深度优先遍历算法类似于二叉树的____。
A. 先序遍历
B. 中序遍历
C. 后序遍历
D. 按层遍历 13.采用邻接表存储的图的宽度优先遍历算法类似于二叉树的____。
A. 先序遍历
B. 中序遍历
C. 后序遍历
D. 按层遍历 14.关键路径是事件结点网络中 。
A.从源点到汇点的最长路径
B.从源点到汇点的最短路径
C.最长的回路
D.最短的回路 15.在图7.3所示的拓朴排列的结果序列为 。
A.125634
B.516234
C.123456
D.521634
16.一个有n 个顶点的无向连通图,它所包含的连通分量个数为 。
A.0 B.1 C.n D.n+1 17.对于一个有向图,若一个顶点的入度为k1,、出度为k2,则对应邻接表
中该顶点单链表中的结点数为 ① ;对应逆邻接表中该顶点单链表中的结点数为 ② 。
A.k1
B.k2
C.k1-k2
D.k1+k2
图5.2 一个有向图的邻接表存储结构
1 2 3 4 5
3
2
4
5
2
4
^
^
^
^ ^ 图7.3有向图
5.2 填空题(将正确的答案填在相应空中)
1.n 个顶点的连通图至少____条边。
2.在无权图G 的邻接矩阵A 中,若(vi,vj)或<vi,vj >属于图G 的边集合,则对应元素A[i][j]等于____,否则等于____。
3.在无向图G 的邻接矩阵A 中,若A[i][j]等于1,则A[j][i ]等于____。
4.已知图G 的邻接表如图5.3所示,其从顶点v1出发的深度优先搜索序列为____,其从顶点v1出发的宽度优先搜索序列为____。
图5.3 图G 的邻接表
5.已知一个有向图的邻接矩阵表示,计算第i 个结点的入度的方法是____。
6.已知一个图的邻接矩阵表示,删除所有从第i 个结点出发的边的方法是____。
7.一个图的 表示法是唯一的,而 表示法是不唯一的。
8.有向图中的结点前驱后继关系的特征是 。
9.假设一个有向图的边集为{<a,c>,<a,e>,<c,f>,<d,c><e,b>,<e,d>},对该图进行拓扑排序的顶点序列为 。
5.3 综合题
1.已知如图5.4所示的有向图,请给出该图的: (1)每个顶点的入/出度; (2)邻接矩阵; (3)邻接表; (4)逆邻接表; (5)强连通分量。
图5.4一个有向图
2.请用克鲁斯卡尔和普里姆两种算法分别为图5.5、图5.6构造最小生成树:
(1)
图5.5
(2
图5.6
3.试列出图5.7中全部的拓扑排序序列。
图5.7
4.请用图示说明图5.8从顶点a 到其余各顶点之间的最短路径。
图5.8
5.已知AOE网有9个结点:V1,V2,V3,V4,V5,V6,V7,V8,V9,其邻接矩阵如下:
(1)请画出该AOE图。
(2)计算完成整个计划需要的时间。
(3)求出该AOE网的关键路径。
5.4 编程题
1.假设有向图以邻接表存储,计算各顶点的出度和入度。
2.假设有向图以邻接表存储,试编写算法删除弧<Vi,Vj>的算法。