1、数据结构基础概念试题数据结构试题一、 单选题1、 在数据结构的讨论中把数据结构从逻辑上分为 (C ) A 内部结构与外部结构 B 静态结构与动态结构 C 线性结构与非线性结构 D 紧凑结构与非紧凑结构。2、采用线性链表表示一个向量时,要求占用的存储空间地址(D ) A 必须是连续的 B 部分地址必须是连续的 C 一定是不连续的 D 可连续可不连续3、采用顺序搜索方法查找长度为n的顺序表时,搜索成功的平均搜索长度为( D )。 A n B n/2 C (n-1)/2 D (n+1)/24、在一个单链表中,若q结点是p结点的前驱结点,若在q与p之间插入结点s,则执行( D )。A slink =
2、plink; plink = s; B plink = s; slink = q;C plink = slink; slink = p; D qlink = s; slink = p;5、如果想在4092个数据中只需要选择其中最小的5个,采用( C )方法最好。 A 起泡排序 B 堆排序 C 锦标赛排序 D 快速排序 6、设有两个串t和p,求p在t中首次出现的位置的运算叫做( B )。 A 求子串 B 模式匹配 C 串替换 D 串连接7、在数组A中,每一个数组元素Aij占用3个存储字,行下标i从1到8,列下标j从1到10。所有数组元素相继存放于一个连续的存储空间中,则存放该数组至少需要的存储字
3、数是( C )。A 80 B 100 C 240 D 2708、将一个递归算法改为对应的非递归算法时,通常需要使用( A )。A 栈 B 队列 C 循环队列 D 优先队列9、一个队列的进队列顺序是1, 2, 3, 4,则出队列顺序为( C )。10、在循环队列中用数组A0.m-1 存放队列元素,其队头和队尾指针分别为front和rear,则当前队列中的元素个数是( D )。 A ( front - rear + 1) % m B ( rear - front + 1) % mC ( front - rear + m) % m D ( rear - front + m) % m11、一个数组元素
4、ai与( A )的表示等价。A *(a+i) B a+i C *a+i D &a+i 12、若需要利用形参直接访问实参,则应把形参变量说明为( B )参数。A 指针 B 引用 C 值 D 变量13、下面程序段的时间复杂度为( C ) for (int i=0;im;i+) for (int j=0;jlink=p;p-link=s;B s-link=p-link;p-link=s;C s-link=p-link;p=s;D p-link=s;s-link=p;19、设单链表中结点结构为(data,link).已知指针q所指结点是指针p所指结点的直接前驱,若在*q与*p之间插入结点*s,则应执行
5、下列哪一个操作( B )A s-link=p-link; p-link=s; B q-link=s; s-link=pC p-link=s-link; s-link=p; D p-link=s; s-link=q;20、设单链表中结点结构为(data,link).若想摘除结点*p的直接后继,则应执行下列哪一个操作( A )A p-link=p-link-link; B p=p-link; p-link=p-link-link;C p-link=p-link; D p=p-link-link;21、设单循环链表中结点的结构为(data,link),且rear是指向非空的带表头结点的单循环链表的尾
6、结点的指针。若想删除链表第一个结点,则应执行下列哪一个操作( D )A s=rear; rear=rear-link; delete s; B rear=rear-link; delete rear; C rear=rear-link-link; delete rear; D s=rear-link-link; rear-link-link=s-link; delete s;22、设单循环链表中结点的结构为(data,link),且first为指向链表表头的指针,current为链表当前指针,在循环链表中检测current是否达到链表表尾的语句是( D )。A current-link =nu
7、ll B first-link=currentC first=current D current-link=first23、一个栈的入栈序列为a,b,c,则出栈序列不可能的是( C )。A c,b,a B b,a,c C c,a,b D a,c,b24、栈的数组表示中,top为栈顶指针,栈空的条件是( A )。A top=0 B top=maxSize C top=maxSize D top=-125、栈和队列的共同特点是( C )。A 都是先进后出 B 都是先进先出C 只允许在端点处插入和删除 D 没有共同点26、假定一个顺序存储的循环队列的队头和队尾指针分别为f和r ,则判断队空的条件为(
8、 D ).A f+1= =r B r+1= =f C f= =0 D f= =r27、当利用大小为n 的数组顺序存储一个队列时,该队列的最大长度为( B )A n-2 B n-1 C n D n+128、当利用大小为n 的数组顺序存储一个栈时,假定用top= =n 表示栈空,则向这个栈插入一个元素时,首先应执行( )语句修改top指针。A top+; B top-; C top=0; D top;29、设链式栈中结点的结构为(data, link),且top是指向栈顶的指针。若想摘除链式栈的栈顶结点,并将被摘除结点的值保存到x中,则应执行下列( A )操作。A x=top-data; top=
9、top-link; B top=top-link; x=top-data; C x=top; top=top-link; D x=top-data;30、设循环队列的结构是: const int Maxsize=100; typedef int Data Type; typedef struct Data Type dataMaxsize; Int front, rear; Queue;若有一个Queue类型的队列Q,试问判断队列满的条件应是下列哪一个语句( D )A Q.front= = Q.rear; B Q.front - Q.rear= = Maxsize; C Q.front + Q
10、.rear= = Maxsize; D Q.front= = (Q.rear+1)% Maxsize;31、设有一个递归算法如下:int fact (int n ) if (n=0) return 1;else return n*fact(n-1);下面正确的叙述是( B )A 计算fact(n) 需要执行n次递归 B fact(7)=5040 C 此递归算法最多只能计算到fact(8) D 以上结论都不对32、设有一个递归算法如下int x (int n) if (n递归表纯表线性表 B 递归表线性表再入表纯表 C 递归表再入表纯表线性表 D递归表再入表线性表纯表37、某二叉树的前序和后序序
11、列正好相反,则该二叉树一定是(B)的二叉树。A 空或只有一个结点 B 高度等于其结点数 C 任一结点无左孩子 D 任一结点无右孩子38、对于任何一棵二叉树T,如果其终端结点数为n0,度为2的结点为n2.,则( A )A n0= n2+1 B n2= n0+1 C n0= 2n2+1 D n2=2n0+1 39、 由权值分别为11,8,6,2,5的叶子结点生成一棵哈夫曼树,它的带权路径长度为(B )A 24 B 73 C 48 D 5340、已知一个顺序存储的线性表,设每个结点需占m个存储单元,若第一个结点的地址为da1,则第I 个结点的地址为(A)。A da1+(I-1)*m B da1+I*
12、m C da1-I*m D da1+(I+1)*m41、34 具有35个结点的完全二叉树的深度为( A )A 5 B 6 C 7 D 842、对线性表进行折半搜索时,要求线性表必须( C )A 以链接方式存储且结点按关键码有序排列 B 以数组方式存储 C 以数组方式存储且结点按关键码有序排列 D以链接方式存储43、顺序搜索算法适合于存储结构为( B )的线性表。A 散列存储 B 顺序存储或链接存储 C 压缩存储 D 索引存储44、采用折半搜索算法搜索长度为n的有序表时,元素的平均搜索长度为( C )A O(n2) B O(n log2n) C O(log2n) D O(n)45、对于一个具有n
13、个顶点和e条边的无向图,进行拓扑排序时,总的时间为( A )A n B n+1 C n-1 D n+e46、判断一个有向图是否存在回路,除了可以利用拓扑排序方法外,还可以利用(C )。A 求关键路径的方法 B 求最短路径的Dijkstra方法 C 深度优先遍历算法 D 广度优先遍历算法47、在10阶B-树中根结点所包含的关键码个数最多为(C ),最少为( A )A 1 B 2 C 9 D 1048、对包含n 个元素的散列表进行搜索,平均搜索长度为( C )A O(log2n) B O(n) C 不直接依赖于n D 上述都不对二、 填空题()1、数据的逻辑结构被分为集合结构、线性结构、树形结构、
14、图形结构 四种2、数据的存储结构被分为顺序结构、链接结构、索引结构、散列结构 四种3、一种抽象数据类型包括(数据 )和(操作 )两个部分。4、 设有两个串p和q,求p在q中首次出现的位置的运算称为(模式匹配) 5、 栈、队列逻辑上都是(线性存储)结构。6、 线性结构反映结点间的逻辑关系是(一对一)的,图中的数据元素之间的关系是(多对多)的,树形结构中数据元素间的关系是(一对多)的。7、栈中存取数据的原则(后进先出),队列中存取数据的原则(先进先出)8、串是由(零个或多个)字符组成的序列。(长度为零的串)称为空串,(由一个或多个空格组成的串)称为空格串。9、设目标串T=”abccdcdccbaa
15、”,模式P=”cdcc”则第(6)次匹配成功。10、一维数组的逻辑结构是(线性结构),存储结构是(顺序存储表示)。对于二维数组,有(行优先顺序)和(列优先顺序)两种不同的存储方式,对于一个二维数组Amn,若采用按行优先存放的方式,则任一数组元素Aij相对于A00的地址为( n*i+j)。11、向一个顺序栈插入一个元素时,首先使( 栈顶指针 )后移一个位置,然后把待插入元素( 写 )到这个位置上。从一个顺序栈删除元素时,需要前移一位(栈顶指针)。12、在一个循环队列Q中,判断队空的条件为(Q.front= =Q.rear), 判断队满的条件为( (Q.rear+1)%MaxSize= =q.fr
16、ont )13、对于一棵具有n个结点的树,该树中所有结点的度数之和为( n-1 )。14、一棵高度为5的满二叉树中的结点数为( 63 )个,一棵高度为3满四叉树中的结点数为( 85 )个。15、若对一棵二叉树从0开始进行结点编号,并按此编号把它顺序存储到一维数组中,即编号为0的结点存储到a0中,其余类推,则ai元素的左子女结点为( 2*i+1),右子女结点为( 2*i+2 ),双亲结点(i=1)为((i-1)/2 ).16、在一个最大堆中,堆顶结点的值是所有结点中的(最大值),在一个最小堆中,堆顶结点的值是所有结点中的(最小值)。17、已知具有n个元素的一维数组采用顺序存储结构,每个元素占k个
17、存储单元,第一个元素的地址为LOC(a1),那么,LOC(ai)= LOC(a1)+(i-1)*k 。18、在霍夫曼编码中,若编码长度只允许小于等于4,则除掉已对两个字符编码为0和10外,还可以最多对( 4 )个字符编码。19、设高度为h的空二叉树的高度为-1,只有一个结点的二叉树的高度为0,若设二叉树只有度为2上度为0的结点,则该二叉树中所含结点至少有(2h+1)个。20、由一棵二叉树的前序序列和(中序序列)可唯一确定这棵二叉树。 21、以折半搜索方法搜索一个线性表时,此线性表必须是(顺序)存储的(有序)表。22、已知完全二叉树的第8层有8个结点,则其叶子结点数是(68)。若完全二叉树的第7
18、有10个叶子结点,则整个二叉树的结点数最多是(235)23、对于折半搜索所对应的判定树,它既是一棵(二叉搜索树),又是一棵(理想平衡树)。24、假定对长度n=50的有序表进行折半搜索,则对应的判定树高度为(),判定树中前层的结点数为(),最后一层的结点数为()。25、在一个无向图中,所有顶点的度数之和等于所有边数的()倍。在一个具有n个顶点的无向完全图中,包含有( n(n-1)/2 )条边,在一个具有n个顶点的有向完全图中,包含有( n(n-1) )条边。26、对于一个具有n个顶点和e条边的连通图,其生成树中的顶点数和边数分别为(n)和(n-1)。27、设线性表中元素的类型是实型,其首地址为1
19、024,则线性表中第6个元素的存储位置是( 1044)。28、在插入和选择排序中,若初始数据基本正序,则选择(插入排序),若初始数据基本反序,则最好选择(选择排序)。29、算法是对特定问题的求解步驟的一种描述,它是(指令)的有限序列,每一条(指令)表示一个或多个操作。30、对于一个具有n个顶点肯e 条边的无向图,进行拓朴排序时,总的进间为(n)31、构造哈希函数有三种方法,分别为(平方取中)法、(除留余数)法、(折迭移位)法。32、处理冲突的三种方法,分别为(线性探测)、( 随机探测 )、( 链地址法)。33、对于含有n个顶点和e条边的无向连通图,利用普里姆算法产生的最小生成树,其时间复杂度为
20、( (n2) )、利用克鲁斯卡尔算法产生的最小生成树,其时间复杂度为(elog2e) )34、快速排序在平均情况下的时间复杂度为(nlog2n),在最坏情况下的时间复杂度为(n2);快速排序在平均情况下的空间复杂度为(log2n),在最坏情况下的空间复杂度为(n)。35、假定一组记录的排序码为(,),对其进行归并排序的过程中,第二趟排序后的结果是()36、假定一组记录的排序码为(,),对其进行快速排序的第一次划分的结果是()。37、一个结点的子树的( 个数 )称为该结点的度。度为( 零 )的结点称为叶结点或终端结点。度不为( 零 )的结点称为分支结点或非终端结点。树中各结点度的( 最大值 )称
21、为树的度。38、设Ki=Kj (1=i=n, 1=j=n,ji)且在排序前的序列中Ri领先于Rj (ij),若排序后的序列中Ri仍领先于Rj,则这种排序方法是(稳定的),反之是(不稳定的)。40 、在堆排序的过程中,对任一分支结点进行调整运算的时间复杂度为(log2n),整个排序过程的时间复杂度为(nlog2n)。41、在索引表中,每个索引项至少包含有(关键码值)域和(子表地址)域这两项。42、假定一个线性表为(”abcd”,”baabd”,”bcef”,”cfg”,”ahij”,”bkwte”,”ccdt”,”aayb”),若按照字符串的第一个字母进行划分,使得同一个字母被划分在一个子表中,
22、则得到的a,b,c三个子表的长度分别为(),(),()。43、对于包含个关键码的阶B-树,其最小高度为(),最大高度为()。44、从一棵B-树删除关键码的过程,若最终引起树根结点的合并,则新树比原树的高度(减)45、假定要对长度n=100的线性表进行散列存储,并采用开散列法处理冲突,则对于长度m=20的散列表,每个散列地址的同义词子表的长度平均为()。46、在散列存储中,装载因子又称为装载系数,若用m表示散列表的长度,n表示待散列存储的元素的个数,则等于(n/m)。47、在有向图的邻接矩阵中,第i行中“1”的个数是第i个顶点的(出度),第i列中“1”的个数是第i个顶点的(入度)。在无向图的邻接
23、矩阵中,第i行(列)中“1”的个数是第i个顶点的(度),矩阵中“1”的个数的一半是图中的(边数)。48、在对m阶B-树中,每个非根结点的关键码数最少为(m/2-1)个,最多为(m-1)个,其子树棵数最少为(m/2),最多为(m)。三、 判断题1、 数据元素是数据的最小单位()。2、 数据的逻辑结构是指各数据元素之间的逻辑关系,是用户按使用需要建立的().3、 数据结构是指相互之间存在一种或多种关系的数据元素的全体()。4、 从逻辑关系上讲,数据结构主要分为两大类:线性结构和非线性结构()。5、 线性表的逻辑顺序与物理顺序总是一致的()。6、 二维数组是其数组元素为线性表的线性表()。7、 每种
24、数据结构都应具备三种基本运算:插入、删除、搜索()。8、 非空线性表中任意一个数据元素都有且仅有一个直接前驱元素。( )9、 空串与由空格组成的串没有区别。( )10、将T在S中首次出现的位置作为T在S中的位置的操作称为串的模式匹配。()11、深度为h的非空二叉树的第h层最多有2h-1个结点( )12、完全二叉树就是满二叉树。()13、已知一棵二叉树的前序序列和中序序列可以唯一地构造出该二叉树。( )14、带权连通图的最小生成树的权值之和一定小于它的其它生成树的权值之和。()15、线性表的顺序存储结构的特点是逻辑关系上相邻的两个元素在物理位置上也相邻。()16、 若有一个结点是二叉树中某个子树
25、的中序遍历结果序列的最后一个结点,则它一定是该子树的前序遍历结果序列的最后一个结点。()17、任一棵二叉搜索树的平均搜索时间都小于用顺序搜索法搜索同样结点的顺序表的平均搜索时间。()18、最优二叉搜索树一定是平衡的二叉搜索树。()19、AOE网是一种带权的无环连通图。( )20、对于同一组待输入的关键码集合,虽然各关键码的输入次序不同,但得到的二叉搜索树都是相同的()。21、二叉排序树可以是一棵空树()22、线性表中所有结点的类型必须相同。 ()23、n个结点的有向图,若它有n(n1)条边,则它一定是强连通的。()24、任何无环的有向图,其结点都可以排在一个拓扑序列里。( )25、队列逻辑上是
26、一个下端口和上端能增加又能减少的线性表( )26、二叉树是树的一种特殊情况( )27、用邻接矩阵存储一个图时,在不考虑压缩存储的情况下,所占用的存储空间大小只与图中顶点个数有关,而与图的边数无关()。28、邻接表只能用于有向图的存储,邻接矩阵对于有向图和无向图的存储都适用。()29、连通分量是无向图中的极小连通子图。()30、在网络中一定只有一条关键路径。()31、关键活动不按期完成就会影响整个工程的完成时间。()32、平衡二叉树的左右子树深度之差的绝对值不超过1。( )33、快速排序是对起泡排序的一种改进。()34、直接选择排序稳定。()35、堆排序占用的辅助空间很大。()36、在散列法中采
27、取开散列法来解决冲突时,其装载因子的取值一定在(,)之间。()37、B-树是一种动态索引结构,它既适用于随机搜索,也适用于顺序搜索。()38、在散列法中,一个可用散列函数必须保证绝对不产生冲突。()39、任何一个关键活动延迟,那么整个工程将会延迟。()40、任何一个关键活动提前完成,那么整个工程将会提前完成。()四、运算应用题 1、在一个有n个元素的顺序表的第i个元素(1 i n)之前插入一个新元素时,需要向后移动多少个元素?答案:需要向后移动 n- i + 1个元素2、 当一个栈的进栈序列为时,可能的出栈序列有多少种?是否是合理的出栈序列?答案: 可能的出栈序列有种,不是合理的出栈序列。3、 简单(直接)选择排序是一种稳定的排序方法吗?试举例说明?答案:是不稳定的排序方法。下面就是不稳定的例子。只要能举出反例即可。 275 275* 512 061 i = 1 061 275* 512 275 i = 2 061 275* 512 275
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1