数据结构复习题.docx
- 文档编号:12375599
- 上传时间:2023-04-18
- 格式:DOCX
- 页数:25
- 大小:52.96KB
数据结构复习题.docx
《数据结构复习题.docx》由会员分享,可在线阅读,更多相关《数据结构复习题.docx(25页珍藏版)》请在冰豆网上搜索。
数据结构复习题
数据结构试题
一、单选题
1、在数据结构的讨论中把数据结构从逻辑上分为()
A内部结构与外部结构B静态结构与动态结构
C线性结构与非线性结构D紧凑结构与非紧凑结构。
2、采用线性链表表示一个向量时,要求占用的存储空间地址()
A必须是连续的B部分地址必须是连续的
C一定是不连续的D可连续可不连续
3、采用顺序搜索方法查找长度为n的顺序表时,搜索成功的平均搜索长度为()。
AnBn/2C(n-1)/2D(n+1)/2
4、在一个单链表中,若q结点是p结点的前驱结点,若在q与p之间插入结点s,则执行()。
As→link=p→link;p→link=s;
Bp→link=s;s→link=q;
Cp→link=s→link;s→link=p;
Dq→link=s;s→link=p;
5、如果想在4092个数据中只需要选择其中最小的5个,采用()方法最好。
A起泡排序B堆排序C锦标赛排序D快速排序
6、设有两个串t和p,求p在t中首次出现的位置的运算叫做()。
A求子串B模式匹配C串替换D串连接
7、在数组A中,每一个数组元素A[i][j]占用3个存储字,行下标i从1到8,列下标j从1到10。
所有数组元素相继存放于一个连续的存储空间中,则存放该数组至少需要的存储字数是()。
A80B100C240D270
8、将一个递归算法改为对应的非递归算法时,通常需要使用()。
A栈B队列C循环队列D优先队列
9、一个队列的进队列顺序是1,2,3,4,则出队列顺序为()。
10、在循环队列中用数组A[0..m-1]存放队列元素,其队头和队尾指针分别为front和rear,则当前队列中的元素个数是()。
A(front-rear+1)%mB(rear-front+1)%m
C(front-rear+m)%mD(rear-front+m)%m
11、一个数组元素a[i]与()的表示等价。
A*(a+i)Ba+iC*a+iD&a+i
12、若需要利用形参直接访问实参,则应把形参变量说明为()参数。
A指针B引用C值D变量
13、下面程序段的时间复杂度为()
for(inti=0;i for(intj=0;j a[i][j]=i*j; AO(m2)BO(n2)CO(m*n)DO(m+n) 14、下面程序段的时间复杂度为() intf(unsignedintn){ if(n==0||n==1)return1; elsereturnn*f(n-1); } AO (1)BO(n)CO(n2)DO(n! ) 15、线性表若是采用链式存储结构时,要求内存中可用存储单元的地址()。 A必须是连续的 B 部分地址必须是连续的 C一定是不连续的 D 连续或不连续都可以 16、数据结构的定义为(D,S),其中D是()的集合。 A算法B数据元素C数据操作D逻辑结构 17、算法分析的目的是()。 A 找出数据结构的合理性 B 研究算法中输入和输出的关系 C 分析算法的效率以求改进 D 分析算法的易懂性和文档性 18、在一个单链表中,若p所指结点不是最后结点,在p之后插入s所指结点,则执行()。 As->link=p;p->link=s; Bs->link=p->link;p->link=s; Cs->link=p->link;p=s; Dp->link=s;s->link=p; 19、设单链表中结点结构为(data,link).已知指针q所指结点是指针p所指结点的直接前驱,若在*q 与*p之间插入结点*s,则应执行下列哪一个操作() As->link=p->link;p->link=s;Bq->link=s;s->link=p Cp->link=s->link;s->link=p;Dp->link=s;s->link=q; 20、设单链表中结点结构为(data,link).若想摘除结点*p的直接后继,则应执行下列哪一个操作() Ap->link=p->link->link; Bp=p->link;p->link=p->link->link; Cp->link=p->link;Dp=p->link->link; 21、设单循环链表中结点的结构为(data,link),且rear是指向非空的带表头结点的单循环链表的尾结点的指针。 若想删除链表第一个结点,则应执行下列哪一个操作() As=rear;rear=rear->link;deletes; Brear=rear->link;deleterear; Crear=rear->link->link;deleterear; Ds=rear->link->link;rear->link->link=s->link;deletes;s为第一个结点硫 22、设单循环链表中结点的结构为(data,link),且first为指向链表表头的指针,current为链表当前指针,在循环链表中检测current是否达到链表表尾的语句是()。 Acurrent->link=nullBfirst->link=current Cfirst=currentDcurrent->link=first ? 23、一个栈的入栈序列为a,b,c,则出栈序列不可能的是()。 A c,b,aBb,a,cCc,a,bDa,c,b 24、栈的数组表示中,top为栈顶指针,栈空的条件是(A)。 A top=0Btop=maxSizeC top=maxSizeDtop=-1 25、栈和队列的共同特点是()。 A 都是先进后出B都是先进先出 C 只允许在端点处插入和删除D没有共同点 26、假定一个顺序存储的循环队列的队头和队尾指针分别为f和r,则判断队空的条件为(). Af+1==rBr+1==fCf==0Df==r 27、当利用大小为n的数组顺序存储一个队列时,该队列的最大长度为() An-2Bn-1CnDn+1 28、当利用大小为n的数组顺序存储一个栈时,假定用top==n表示栈空,则向这个栈插入一个元素时,首先应执行()语句修改top指针。 Atop++;Btop--;Ctop=0;Dtop; 29、设链式栈中结点的结构为(data,link),且top是指向栈顶的指针。 若想摘除链式栈的栈顶结点,并将被摘除结点的值保存到x中,则应执行下列()操作。 Ax=top->data;top=top->link;Btop=top->link;x=top->data; Cx=top;top=top->link;Dx=top->data; 30、设循环队列的结构是: constintMaxsize=100; typedefintDataType; typedefstruct{ DataTypedata[Maxsize]; Intfront,rear; }Queue; 若有一个Queue类型的队列Q,试问判断队列满的条件应是下列哪一个语句() AQ.front==Q.rear;BQ.front-Q.rear==Maxsize; CQ.front+Q.rear==Maxsize;DQ.front==(Q.rear+1)%Maxsize; 31、设有一个递归算法如下: intfact(intn) {if(n<=0)return1; elsereturnn*fact(n-1); } 下面正确的叙述是() A计算fact(n)需要执行n次递归Bfact(7)=5040 C此递归算法最多只能计算到fact(8)D以上结论都不对 32、设有一个递归算法如下 intx(intn){ if(n<=3)return1; elsereturnx(n-2)+x(n-4)+1; } 试问计算x(x(8))时需要计算()次x函数。 A8次B9次C16次D18次 33、设有广义表D(a,b,D),其长度为(B),深度为() A∞B3C2D5 34、广义表A(a),则表尾为(C) AaB(())C空表D(a) 35、下列广义表是线性表的有() AE(a,(b,c))BE(a,E)CE(a,b)DE(a,L()) 36、递归表、再入表、纯表、线性表之间的关系为() A再入表>递归表>纯表>线性表B递归表>线性表>再入表>纯表 C递归表>再入表>纯表>线性表D递归表>再入表>线性表>纯表 37、某二叉树的前序和后序序列正好相反,则该二叉树一定是( )的二叉树。 A空或只有一个结点 B高度等于其结点数 C任一结点无左孩子 D任一结点无右孩子 38、对于任何一棵二叉树T,如果其终端结点数为n0,度为2的结点为n2.,则() An0=n2+1Bn2=n0+1Cn0=2n2+1Dn2=2n0+1 39、由权值分别为11,8,6,2,5的叶子结点生成一棵哈夫曼树,它的带权路径长度为() A24B73C48D53 40、已知一个顺序存储的线性表,设每个结点需占m个存储单元,若第一个结点的地址为da1,则第I个结点的地址为( )。 Ada1+(I-1)*m Bda1+I*m Cda1-I*m Dda1+(I+1)*m 41、34具有35个结点的完全二叉树的深度为() A5B6C7D8 42、对线性表进行折半搜索时,要求线性表必须() A以链接方式存储且结点按关键码有序排列B以数组方式存储 C以数组方式存储且结点按关键码有序排列D以链接方式存储 43、顺序搜索算法适合于存储结构为()的线性表。 A散列存储B顺序存储或链接存储 C压缩存储D索引存储 44、采用折半搜索算法搜索长度为n的有序表时,元素的平均搜索长度为() AO(n2)BO(nlog2n)CO(log2n)DO(n) 45、对于一个具有n个顶点和e条边的无向图,进行拓扑排序时,总的时间为() AnBn+1Cn-1Dn+e 46、判断一个有向图是否存在回路,除了可以利用拓扑排序方法外,还可以利用()。 A求关键路径的方法B求最短路径的Dijkstra方法 C深度优先遍历算法D广度优先遍历算法 47、在10阶B-树中根结点所包含的关键码个数最多为(),最少为() A1B2C9D10 48、对包含n个元素的散列表进行搜索,平均搜索长度为() AO(log2n)BO(n)C不直接依赖于nD上述都不对 二、填空题() 1、 数据的逻辑结构被分为四种 2、 数据的存储结构被分为四种 3、一种抽象数据类型包括()和()两个部分。 4、设有两个串p和q,求p在q中首次出现的位置的运算称为() 5、 栈、队列逻辑上都是()结构。 6、线性结构反映结点间的逻辑关系是()的,图中的数据元素之间的关系是()的,树形结构中数据元素间的关系是()的。 7、栈中存取数据的原则( ),队列中存取数据的原则( ) 8、串是由( )字符组成的序列。 ( )称为空串,( )称为空格串。 9、设目标串T=”abccdcdccbaa”,模式P=”cdcc”则第()次匹配成功。 10、一维数组的逻辑结构是(),存储结构是()。 对于二维数组,有()和()两种不同的存储方式,对于一个二维数组A[m][n],若采用按行优先存放的方式,则任一数组元素A[i][j]相对于A[0][0]的地址为()。 11、向一个顺序栈插入一个元素时,首先使()后移一个位置,然后把待插入元素()到这个位置上。 从一个顺序栈删除元素时,需要前移一位()。 12、在一个循环队列Q中,判断队空的条件为(),判断队满的条件为() 13、对于一棵具有n个结点的树,该树中所有结点的度数之和为()。 14、一棵高度为5的满二叉树中的结点数为()个,一棵高度为3满四叉树中的结点数为()个。 15、若对一棵二叉树从0开始进行结点编号,并按此编号把它顺序存储到一维数组中,即编号为0的结点存储到a[0]中,其余类推,则a[i]元素的左子女结点为(),右子女结点为(),双亲结点()为(). 16、在一个最大堆中,堆顶结点的值是所有结点中的(),在一个最小堆中,堆顶结点的值是所有结点中的()。 17、已知具有n个元素的一维数组采用顺序存储结构,每个元素占k个存储单元,第一个元素的地址为LOC(a1),那么,LOC(ai)=。 18、在霍夫曼编码中,若编码长度只允许小于等于4,则除掉已对两个字符编码为0和10外,还可以最多对()个字符编码。 19、设高度为h的空二叉树的高度为-1,只有一个结点的二叉树的高度为0,若设二叉树只有度为2上度为0的结点,则该二叉树中所含结点至少有( )个。 20、由一棵二叉树的前序序列和()可唯一确定这棵二叉树。 21、以折半搜索方法搜索一个线性表时,此线性表必须是()存储的()表。 22、已知完全二叉树的第8层有8个结点,则其叶子结点数是()。 若完全二叉树的第7有10个叶子结点,则整个二叉树的结点数最多是() 23、对于折半搜索所对应的判定树,它既是一棵(),又是一棵()。 24、假定对长度n=50的有序表进行折半搜索,则对应的判定树高度为( ),判定树中前5层的结点数为(),最后一层的结点数为()。 25、在一个无向图中,所有顶点的度数之和等于所有边数的()倍。 在一个具有n个顶点的无向完全图中,包含有()条边,在一个具有n个顶点的有向完全图中,包含有()条边。 26、对于一个具有n个顶点和e条边的连通图,其生成树中的顶点数和边数分别为()和()。 27、设线性表中元素的类型是实型,其首地址为1024,则线性表中第6个元素的存储位置是()。 28、在插入和选择排序中,若初始数据基本正序,则选择(),若初始数据基本反序,则最好选择()。 29、算法是对特定问题的求解步驟的一种描述,它是()的有限序列,每一条()表示一个或多个操作。 30、对于一个具有n个顶点肯e条边的无向图,进行拓朴排序时,总的进间为() 31、构造哈希函数有三种方法,分别为()法、()法、()法。 32、处理冲突的三种方法,分别为()、()、()。 33、对于含有n个顶点和e条边的无向连通图,利用普里姆算法产生的最小生成树,其时间复杂度为()、利用克鲁斯卡尔算法产生的最小生成树,其时间复杂度为() 34、快速排序在平均情况下的时间复杂度为(),在最坏情况下的时间复杂度为();快速排序在平均情况下的空间复杂度为(),在最坏情况下的空间复杂度为()。 35、假定一组记录的排序码为(),对其进行归并排序的过程中,第二趟排序后的结果是() 36、假定一组记录的排序码为(),对其进行快速排序的第一次划分的结果是()。 37、一个结点的子树的()称为该结点的度。 度为()的结点称为叶结点或终端结点。 度不为()的结点称为分支结点或非终端结点。 树中各结点度的()称为树的度。 38、设Ki=Kj(1<=i<=n,1<=j<=n,j<>i)且在排序前的序列中Ri领先于Rj(i 40、在堆排序的过程中,对任一分支结点进行调整运算的时间复杂度为(),整个排序过程的时间复杂度为()。 41、在索引表中,每个索引项至少包含有()域和()域这两项。 42、假定一个线性表为(”abcd”,”baabd”,”bcef”,”cfg”,”ahij”,”bkwte”,”ccdt”,”aayb”),若按照字符串的第一个字母进行划分,使得同一个字母被划分在一个子表中,则得到的a,b,c三个子表的长度分别为(),(),()。 43、对于包含50个关键码的3阶B-树,其最小高度为(),最大高度为()。 44、从一棵B-树删除关键码的过程,若最终引起树根结点的合并,则新树比原树的高度() 45、假定要对长度n=100的线性表进行散列存储,并采用开散列法处理冲突,则对于长度m=20的散列表,每个散列地址的同义词子表的长度平均为()。 46、在散列存储中,装载因子α又称为装载系数,若用m表示散列表的长度,n表示待散列存储的元素的个数,则α等于()。 47、在有向图的邻接矩阵中,第i行中“1”的个数是第i个顶点的(),第i列中“1”的个数是第i个顶点的()。 在无向图的邻接矩阵中,第i行()中“1”的个数是第i个顶点的(),矩阵中“1”的个数的一半是图中的()。 48、在对m阶B-树中,每个非根结点的关键码数最少为()个,最多为()个,其子树棵数最少为(),最多为()。 三、判断题 1、数据元素是数据的最小单位()。 2、数据的逻辑结构是指各数据元素之间的逻辑关系,是用户按使用需要建立的(). 3、数据结构是指相互之间存在一种或多种关系的数据元素的全体()。 4、从逻辑关系上讲,数据结构主要分为两大类: 线性结构和非线性结构()。 5、线性表的逻辑顺序与物理顺序总是一致的()。 6、二维数组是其数组元素为线性表的线性表()。 7、每种数据结构都应具备三种基本运算: 插入、删除、搜索()。 8、非空线性表中任意一个数据元素都有且仅有一个直接前驱元素。 () 9、空串与由空格组成的串没有区别。 () 10、将T在S中首次出现的位置作为T在S中的位置的操作称为串的模式匹配。 () 11、深度为h的非空二叉树的第h层最多有2h-1个结点() 12、完全二叉树就是满二叉树。 () 13、已知一棵二叉树的前序序列和中序序列可以唯一地构造出该二叉树。 () 14、带权连通图的最小生成树的权值之和一定小于它的其它生成树的权值之和。 () 15、线性表的顺序存储结构的特点是逻辑关系上相邻的两个元素在物理位置上也相邻。 ( ) 16、若有一个结点是二叉树中某个子树的中序遍历结果序列的最后一个结点,则它一定是该子树的前序遍历结果序列的最后一个结点。 () 17、任一棵二叉搜索树的平均搜索时间都小于用顺序搜索法搜索同样结点的顺序表的平均搜索时间。 () 18、最优二叉搜索树一定是平衡的二叉搜索树。 () 19、AOE网是一种带权的无环连通图。 () 20、对于同一组待输入的关键码集合,虽然各关键码的输入次序不同,但得到的二叉搜索树都是相同的()。 21、二叉排序树可以是一棵空树( ) 22、线性表中所有结点的类型必须相同。 ( ) 23、n个结点的有向图,若它有n(n-1)条边,则它一定是强连通的。 ( ) 24、任何无环的有向图,其结点都可以排在一个拓扑序列里。 ( ) 25、队列逻辑上是一个下端口和上端能增加又能减少的线性表() 26、二叉树是树的一种特殊情况() 27、用邻接矩阵存储一个图时,在不考虑压缩存储的情况下,所占用的存储空间大小只与图中顶点个数有关,而与图的边数无关()。 28、邻接表只能用于有向图的存储,邻接矩阵对于有向图和无向图的存储都适用。 () 29、连通分量是无向图中的极小连通子图。 () 30、在AOE网络中一定只有一条关键路径。 ( 31、关键活动不按期完成就会影响整个工程的完成时间。 () 32、平衡二叉树的左右子树深度之差的绝对值不超过1。 () 33、快速排序是对起泡排序的一种改进。 ( ) 34、直接选择排序稳定。 ( ) 35、堆排序占用的辅助空间很大。 ( ) 36、在散列法中采取开散列法来解决冲突时,其装载因子的取值一定在(0,1)之间。 () 37、B-树是一种动态索引结构,它既适用于随机搜索,也适用于顺序搜索。 ( ) 38、在散列法中,一个可用散列函数必须保证绝对不产生冲突。 () 39、任何一个关键活动延迟,那么整个工程将会延迟。 () 40、任何一个关键活动提前完成,那么整个工程将会提前完成。 () 四、运算应用题 1、在一个有n个元素的顺序表的第i个元素(1in)之前插入一个新元素时,需要向后移动多少个元素? 2、当一个栈的进栈序列为1234567时,可能的出栈序列有多少种? 6457321是否是合理的出栈序列? 3、简单(直接)选择排序是一种稳定的排序方法吗? 试举例说明? 4、设有序顺序表为{10,20,30,40,50,60,70},采用折半搜索时,搜索成功的平均搜索长度是多少? 5、在结点个数为n(n>1)的各棵树中,高度最小的树的高度是多少? 它有多少个叶结点? 多少个分支结点? 高度最大的树的高度是多少? 它有多少个叶结点? 多少个分支结点? 6、一棵高度为h的满k叉树有如下性质: 第h层上的结点都是叶结点,其余各层上每个结点都有k棵非空子树,如果按层次自顶向下,同一层自左向右,顺序从1开始对全部结点进行编号,试问: (1)各层的结点个数是多少? (2)编号为i的结点的父结点(若存在)的编号是多少? (3)编号为i的结点的第m个孩子结点(若存在)的编号是多少? (4)编号为i的结点有右兄弟的条件是什么? 其右兄弟结点的编号是多少? (5)若结点个数为n,则高度h是n的什么函数关系? (5)若结点个数为n,则高度h和n的关系为: h=logk(n*(k-1)+1)-1(n=0时h=-1) 7、写出下列中缀表达式的后缀形式: (1)A*-B+C (2)(A+B)*D+E/(F+A*D)+C (3)A&&B||! (E>F){注: 按C++的优先级) (4)! (A&&! ((B 8、画出下列广义表的图形表示和它们的存储表示: (1)D(A(c),B(e),C(a,L(b,c,d))) (2)J1(J2(J1,a,J3(J1)),J3(J1)) 答案: 广义表 (1)的图形表示为: 广义表 (2)的图形表示为: 9、题目: 11、将下面的森林变换成二叉树(7分)。 10、将算术表达式((a
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 复习题