2022年数据结构习题全集和答案归纳 .pdf
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_05.gif)
《2022年数据结构习题全集和答案归纳 .pdf》由会员分享,可在线阅读,更多相关《2022年数据结构习题全集和答案归纳 .pdf(37页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、数据结构习题与解析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)/2 4、在一个单链表中,若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 ) 。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 37 页 - - - - - - - - - 数据结构习题与解析2 A 80 B 100 C 240 D 270 8、将一个递归算法改为对应的非递归算法时,通常需要使用( A ) 。A 栈B 队列C 循环队列D 优先队列9、一个队列的进队列顺序是1, 2, 3, 4,则出队列顺序为( C ) 。10、在循环队列中用数组A0. m -1 存放队列元素,其队头和队尾指针分别为front
4、和 rear ,则当前队列中的元素个数是( D ) 。A ( front - rear + 1) % m B ( rear - front + 1) % mC ( front - rear + m ) % m D ( rear - front + m ) % m 11、一个数组元素 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;
5、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 ,则应执行下列哪一个操作 ( B )A s-link=p-link; p-link=s; B q-link=s; s-link=p C p-link=s-link; s-link=p; D p-link=s; s-link=q; 20、设单链表中结点结构为 (data,link).若想摘除结点
6、*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 是指向非空的带表头结点的单循环链表的尾结点的指针。若想删除链表第一个结点, 则应执行下列哪一个操作( D )A s=rear; rear=rear-link; delete s; B rear=rear-link; delete rear; 名师资料总结 - - -精品资料欢迎下载 - - - - -
7、 - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 37 页 - - - - - - - - - 数据结构习题与解析4 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 =null B fi
8、rst-link=current C first=current D current-link=first 23、一个栈的入栈序列为a,b,c,则出栈序列不可能的是( C )。A c,b,a B b,a,c C c,a,b D a,c,b 24、栈的数组表示中, top 为栈顶指针,栈空的条件是( A )。A top=0 B top=maxSize C top=maxSize D top=-1 25、栈和队列的共同特点是 ( C )。A 都是先进后出 B 都是先进先出C 只允许在端点处插入和删除 D 没有共同点26、假定一个顺序存储的循环队列的队头和队尾指针分别为f 和 r , 则判断队空的条
9、件为 ( D ). A f+1= =r B r+1= =f C f= =0 D f= =r 27、当利用大小为 n 的数组顺序存储一个队列时,该队列的最大长度为( B )A n-2 B n-1 C n D n+1 28、当利用大小为 n 的数组顺序存储一个栈时,假定用top= =n 表示栈空,则向这个栈插入一个元素时,首先应执行()语句修改 top 指针。A top+; B top-; C top=0; D top; 29、设链式栈中结点的结构为(data, link), 且 top 是指向栈顶的指针。若想摘除链式栈的栈顶结点, 并将被摘除结点的值保存到x 中,则应执行下列( A )操作。A
10、x=top-data; top=top-link; B top=top-link; x=top-data; C x=top; top=top-link; D x=top-data; 30、设循环队列的结构是: const int Maxsize=100; 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 37 页 - - - - - - - - - 数据结构习题与解析5 typedef int Data Type; typedef struct Data Type data
11、Maxsize; Int front, rear; Queue; 若有一个 Queue类型的队列 Q ,试问判断队列满的条件应是下列哪一个语句( D )A Q.front= = Q.rear; B Q.front - Q.rear= = Maxsize; C Q.front + Q.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) 需要执行
12、n 次递归 B fact(7)=5040 C 此递归算法最多只能计算到fact(8) D 以上结论都不对32、设有一个递归算法如下int x (int n) if (n递归表 纯表线性表 B 递归表 线性表 再入表 纯表C 递归表 再入表 纯表线性表 D 递归表 再入表 线性表 纯表37、某二叉树的前序和后序序列正好相反,则该二叉树一定是(B )的二叉树。A 空或只有一个结点B 高度等于其结点数C 任一结点无左孩子 D 任一结点无右孩子38、对于任何一棵二叉树T,如果其终端结点数为n0,度为 2 的结点为 n2., 则( A ) A n0= n2+1 B n2= n0+1 C n0= 2n2+
13、1 D n2=2n0+1 39、 由权值分别为 11,8,6,2,5 的叶子结点生成一棵哈夫曼树,它的带权路径长度为( B )A 24 B 73 C 48 D 53 40、已知一个顺序存储的线性表,设每个结点需占 m个存储单元, 若第一个结点的地址为 da1,则第 I 个结点的地址为(A )。A da1+(I-1)*m B da1+I*m C da1-I*m D da1+(I+1)*m 41、34 具有 35 个结点的完全二叉树的深度为( A ) A 5 B 6 C 7 D 8 42、对线性表进行折半搜索时,要求线性表必须( C )名师资料总结 - - -精品资料欢迎下载 - - - - -
14、- - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 6 页,共 37 页 - - - - - - - - - 数据结构习题与解析7 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
15、个顶点和 e 条边的无向图,进行拓扑排序时,总的时间为( A ) A n B n+1 C n-1 D n+e 46、判断一个有向图是否存在回路,除了可以利用拓扑排序方法外,还可以利用(C ) 。A 求关键路径的方法B 求最短路径的 Dijkstra方法C 深度优先遍历算法 D 广度优先遍历算法47、在 10 阶 B-树中根结点所包含的关键码个数最多为(C ) ,最少为 ( A ) A 1 B 2 C 9 D 10 48、对包含 n 个元素的散列表进行搜索,平均搜索长度为( C )A O (log2n) B O(n)C 不直接依赖于 n D 上述都不对二、填空题1、 数据的逻辑结构被分为集合结构
16、、线性结构、树形结构、图形结构四种2、 数据的存储结构被分为顺序结构、链接结构、索引结构、散列结构四种3、一种抽象数据类型包括(数据)和(操作)两个部分。4、设有两个串 p 和 q,求 p 在 q 中首次出现的位置的运算称为(模式匹配)5、 栈、队列逻辑上都是(线性存储)结构。6、 线性结构反映结点间的逻辑关系是(一对一) 的,图中的数据元素之间的关名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 7 页,共 37 页 - - - - - - - - - 数据结构习题与解析8 系是(多
17、对多)的,树形结构中数据元素间的关系是(一对多)的。7、 栈中存取数据的原则 (后进先出), 队列中存取数据的原则 (先进先出)8、串是由(零个或多个)字符组成的序列。(长度为零的串)称为空串,(由一个或多个空格组成的串)称为空格串。9、设目标串 T=”abccdcdccbaa”, 模式 P=”cdcc”则第( 6)次匹配成功。10、一维数组的逻辑结构是(线性结构),存储结构是(顺序存储表示)。对于二维数组,有(行优先顺序)和(列优先顺序)两种不同的存储方式,对于一个二维数组 Amn,若采用按行优先存放的方式, 则任一数组元素 Aij相对于A00的地址为( n*i+j)。11、向一个顺序栈插入
18、一个元素时,首先使(栈顶指针)后移一个位置,然后把待插入元素(写 )到这个位置上。从一个顺序栈删除元素时,需要前移一位(栈顶指针)。12、在一个循环队列 Q中,判断队空的条件为(Q.front= =Q.rear ), 判断队满的条件为( (Q.rear+1)%MaxSize= =q.front )13、对于一棵具有 n 个结点的树,该树中所有结点的度数之和为( n-1 ) 。14、一棵高度为 5 的满二叉树中的结点数为( 63 )个,一棵高度为3 满四叉树中的结点数为( 85 )个。15、若对一棵二叉树从0 开始进行结点编号, 并按此编号把它顺序存储到一维数组中,即编号为0 的结点存储到 a0
19、 中,其余类推,则ai 元素的左子女结点为 ( 2*i+1) , 右子女结点为( 2*i+2 ) , 双亲结点(i=1 ) 为 ( (i-1)/2 ) . 16、在一个最大堆中,堆顶结点的值是所有结点中的(最大值),在一个最小堆中,堆顶结点的值是所有结点中的(最小值)。17、 已知具有 n 个元素的一维数组采用顺序存储结构,每个元素占 k 个存储单元,第一个元素的地址为LOC(a1),那么, LOC(ai)= LOC(a1)+(i-1)*k 。18、在霍夫曼编码中,若编码长度只允许小于等于4, 则除掉已对两个字符编码为 0 和 10 外,还可以最多对( 4 )个字符编码。19、设高度为 h 的
20、空二叉树的高度为 -1 ,只有一个结点的二叉树的高度为0,若设二叉树只有度为2 上度为 0 的结点,则该二叉树中所含结点至少有名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 8 页,共 37 页 - - - - - - - - - 数据结构习题与解析9 (2h+1 )个。20、由一棵二叉树的前序序列和(中序序列)可唯一确定这棵二叉树。21、以折半搜索方法搜索一个线性表时,此线性表必须是 (顺序)存储的(有序)表。22、已知完全二叉树的第8 层有 8 个结点,则其叶子结点数是(68)
21、。若完全二叉树的第 7 有 10 个叶子结点,则整个二叉树的结点数最多是(235)23、对于折半搜索所对应的判定树,它既是一棵(二叉搜索树),又是一棵(理想平衡树)。24、假定对长度 n=50的有序表进行折半搜索,则对应的判定树高度为(5 ) ,判定树中前 5 层的结点数为( 31) ,最后一层的结点数为(19) 。25、在一个无向图中,所有顶点的度数之和等于所有边数的(2)倍。在一个具有 n 个顶点的无向完全图中,包含有( n(n-1)/2 )条边,在一个具有n 个顶点的有向完全图中,包含有( n(n-1) )条边。26、对于一个具有 n 个顶点和 e 条边的连通图, 其生成树中的顶点数和边
22、数分别为(n)和( n-1) 。27、设线性表中元素的类型是实型,其首地址为1024,则线性表中第6 个元素的存储位置是 ( 1044) 。28、在插入和选择排序中,若初始数据基本正序,则选择(插入排序),若初始数据基本反序,则最好选择(选择排序) 。29、算法是对特定问题的求解步驟的一种描述,它是(指令)的有限序列,每一条(指令)表示一个或多个操作。30、对于一个具有 n 个顶点肯 e 条边的无向图,进行拓朴排序时,总的进间为(n)31、构造哈希函数有三种方法,分别为(平方取中 )法、( 除留余数 )法、( 折迭移名师资料总结 - - -精品资料欢迎下载 - - - - - - - - -
23、- - - - - - - - - 名师精心整理 - - - - - - - 第 9 页,共 37 页 - - - - - - - - - 数据结构习题与解析10 位)法。32、处理冲突的三种方法,分别为( 线性探测 ) 、 ( 随机探测) 、 ( 链地址法)。33、对于含有 n 个顶点和 e 条边的无向连通图, 利用普里姆算法产生的最小生成树,其时间复杂度为(n2) ) 、利用克鲁斯卡尔算法产生的最小生成树,其时间复杂度为( elog2e) )34、快速排序在平均情况下的时间复杂度为(nlog2n),在最坏情况下的时间复杂度为(n2) ) ; 快速排序在平均情况下的空间复杂度为( (log2
24、n) ) ,在最坏情况下的空间复杂度为(n)。35、假定一组记录的排序码为(46,79,56,38,40,80) ,对其进行归并排序的过程中,第二趟排序后的结果是( 38 46 56 79 40 80 )36、假定一组记录的排序码为(46,79,56,38,40,80) ,对其进行快速排序的第一次划分的结果是( 38 404656 79 80 ) 。37、一个结点的子树的(个数)称为该结点的度。度为(零)的结点称为叶结点或终端结点。 度不为(零)的结点称为分支结点或非终端结点。树中各结点度的(最大值)称为树的度。38、设 Ki=Kj (1=i=n, 1=j=n,ji)且在排序前的序列中Ri领先
25、于 Rj (i1) 的各棵树中,高度最小的树的高度是多少?它有多少个叶结点?多少个分支结点?高度最大的树的高度是多少?它有多少个叶结点?多少个分支结点?答案:结点个数为 n 时,高度最小的树的高度为1,有 2 层;它有 n-1 个叶结点,1 个分支结点;高度最大的树的高度为n-1, 有 n 层;它有 1 个叶结点, n-1 个分支结点。6、 一棵高度为 h 的满 k 叉树有如下性质 : 第 h 层上的结点都是叶结点 , 其余各层上每个结点都有k 棵非空子树 , 如果按层次自顶向下 , 同一层自左向右 , 顺序从 1 开始对全部结点进行编号 , 试问: 429123456789101112131
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年数据结构习题全集和答案归纳 2022 数据结构 习题 全集 答案 归纳
![提示](https://www.taowenge.com/images/bang_tan.gif)
限制150内