数据结构含答案

合集下载

数据结构期末试题及答案

数据结构期末试题及答案

数据结构期末试题及答案一、单项选择题(每题2分,共20分)1. 在数据结构中,线性表的顺序存储结构和链式存储结构的主要区别在于:A. 数据元素的存储关系B. 数据元素的存储空间C. 数据元素的存储顺序D. 数据元素的存储位置答案:A2. 下列关于栈的描述中,错误的是:A. 栈是一种后进先出(LIFO)的数据结构B. 栈只能进行插入和删除操作C. 栈顶元素可以被访问D. 栈可以进行顺序存储和链式存储答案:B3. 在二叉树的遍历算法中,不使用递归算法的遍历方式是:A. 前序遍历B. 中序遍历C. 后序遍历D. 层序遍历答案:D4. 哈希表的冲突解决方法中,不包括以下哪种:A. 开放定址法B. 链地址法C. 线性探测法D. 排序法答案:D5. 在图的遍历算法中,深度优先搜索(DFS)和广度优先搜索(BFS)的主要区别在于:A. 搜索的顺序B. 存储结构C. 遍历的深度D. 遍历的宽度答案:A6. 快速排序算法的时间复杂度最坏情况下为:A. O(n)B. O(nlogn)C. O(n^2)D. O(n^3)答案:C7. 下列关于二叉搜索树的描述中,正确的是:A. 每个节点的左子树只包含小于该节点的键值B. 每个节点的右子树只包含大于该节点的键值C. 以上两个选项都正确D. 以上两个选项都不正确答案:C8. 在非递归的二叉树遍历算法中,通常需要使用的数据结构是:A. 栈B. 队列C. 链表D. 数组答案:A9. 一个有n个顶点的无向图,其边数最多为:A. nB. n(n-1)/2C. n(n+1)/2D. n^2答案:B10. 一个长度为n的数组进行归并排序时,需要的辅助空间大小为:A. O(1)B. O(n)C. O(nlogn)D. O(n^2)答案:B二、填空题(每题2分,共10分)1. 在数据结构中,______是一种特殊的线性表,它的元素个数是固定的。

答案:数组2. 链表中,每个节点包含数据域和______。

数据结构期末考试试题及答案

数据结构期末考试试题及答案

数据结构期末考试试题及答案一、选择题(每题2分,共20分)1. 在数据结构中,算法的时间复杂度是指()。

A. 编写代码的时间B. 代码的长度C. 执行代码所需的时间D. 执行代码所需的指令条数2. 下列关于队列的描述,错误的是()。

A. 队列是先进先出(FIFO)的线性表B. 队列允许在一端进行插入操作C. 队列的插入操作称为入队D. 队列的删除操作称为出栈3. 对于长度为n的有序数组,使用二分查找法查找一个元素的平均时间复杂度是()。

A. O(n)B. O(n^2)C. O(log n)D. O(1)4. 在图的遍历中,深度优先搜索(DFS)使用的数据结构是()。

A. 栈B. 队列C. 链表D. 数组5. 哈希表的冲突可以通过多种方式解决,以下哪种不是解决冲突的方法?()A. 开放寻址法B. 链地址法C. 线性探测法D. 排序法6. 一个完全二叉树共有700个节点,它的最大节点数是()。

A. 700B. 701C. 1400D. 14017. 快速排序算法的最坏情况发生在()。

A. 每次选择的基准都是最大值B. 数据已经有序C. 数据已经完全逆序D. 所有数据元素相等8. 在一个具有n个节点的二叉搜索树中,最坏情况下查找一个元素的时间复杂度是()。

A. O(n)B. O(log n)C. O(n^2)D. O(1)9. 堆排序算法中,将一个堆调整为最大堆或最小堆的过程称为()。

A. 堆调整B. 堆构建C. 堆分解D. 堆维护10. 以下哪个不是B树的特性?()A. 所有键值都存储在内部节点和叶子节点中B. 所有叶子节点都在同一层上C. 每个内部节点至多有m个子节点D. 每个内部节点的非叶子子节点都至少有m/2个子节点二、简答题(每题5分,共30分)1. 什么是递归?请举例说明递归算法的应用场景。

2. 请简述图的邻接矩阵和邻接表两种存储方式的优缺点。

3. 解释什么是平衡二叉树,并说明它为什么在实际应用中很重要。

数据结构试题集(包含答案-完整版)

数据结构试题集(包含答案-完整版)

数据结构试题集(包含答案-完整版)数据结构试题集(包含答案-完整版)1. 单选题1) 数据结构是一种()。

a) 存储结构b) 算法c) 数据模型d) 网络答案:c) 数据模型解析:数据结构是一种用于组织和存储数据的方式,描述了数据之间的关系以及对数据的操作。

2) 以下哪种数据结构可以通过索引直接访问元素?a) 链表b) 队列c) 栈d) 数组答案:d) 数组解析:数组是一种线性数据结构,可以通过索引直接访问指定位置的元素。

2. 多选题1) 哪些数据结构属于非线性结构?()a) 队列b) 树c) 栈d) 图答案:b) 树d) 图解析:线性结构中的元素存在一对一的关系,非线性结构中的元素存在一对多或多对多的关系,树和图属于非线性结构。

2) 下列哪些操作可以在栈上进行?()a) 入栈b) 出栈c) 查找d) 删除答案:a) 入栈b) 出栈解析:栈是一种后进先出(LIFO)的数据结构,只能在栈顶进行插入和删除操作。

3. 简答题1) 请简要介绍线性表和非线性表。

答案:线性表是数据元素的一个有限序列,元素之间存在一对一的关系。

非线性表是指元素之间存在一对多或多对多的关系,如树和图。

2) 请解释什么是时间复杂度和空间复杂度。

答案:时间复杂度是衡量算法执行效率的度量,表示算法的运行时间随输入规模增长的速度。

空间复杂度是指算法执行过程中所需的存储空间随输入规模增长的速度。

4. 编程题题目:实现一个栈,包含push、pop和getMin三个操作,要求时间复杂度为O(1)。

答案:class MinStack:def __init__(self):self.stack = []self.min_stack = []def push(self, x):self.stack.append(x)if not self.min_stack or x <= self.min_stack[-1]:self.min_stack.append(x)def pop(self):if self.stack.pop() == self.min_stack[-1]:self.min_stack.pop()def getMin(self):return self.min_stack[-1]解析:在栈的基础上,使用一个辅助栈min_stack来记录当前栈中的最小值。

经典数据结构面试题(含答案)

经典数据结构面试题(含答案)

经典数据结构面试题(含答案)1. 什么是数据结构?数据结构是计算机存储、组织数据的方式,它能够更有效地存储数据,以便于进行数据检索和修改。

2. 什么是线性表?线性表是一种基本的数据结构,由一组数据元素组成,其中每个元素都有一个前驱和一个后继,除了第一个元素没有前驱,一个元素没有后继。

3. 什么是栈?栈是一种后进先出(LIFO)的数据结构,它允许在一端进行插入和删除操作,通常称为栈顶。

4. 什么是队列?队列是一种先进先出(FIFO)的数据结构,它允许在一端进行插入操作,在另一端进行删除操作,通常称为队头和队尾。

5. 什么是链表?链表是一种由节点组成的数据结构,每个节点包含数据和指向下一个节点的指针。

链表可以分为单向链表、双向链表和循环链表。

6. 什么是树?树是一种非线性数据结构,由节点组成,每个节点有零个或多个子节点。

树可以分为二叉树、平衡树、B树等。

7. 什么是图?图是一种由节点和边组成的数据结构,节点称为顶点,边表示顶点之间的关系。

图可以分为有向图和无向图。

8. 什么是排序算法?排序算法是一种对数据进行排序的方法,常见的排序算法有冒泡排序、选择排序、插入排序、快速排序、归并排序等。

9. 什么是哈希表?哈希表是一种基于哈希函数的数据结构,它通过哈希函数将键值映射到表中一个位置来快速检索数据。

10. 什么是动态规划?动态规划是一种在数学、管理科学、计算机科学、经济学和生物信息学中使用的,通过把原问题分解为相对简单的子问题的方式求解复杂问题的方法。

经典数据结构面试题(含答案)11. 什么是二叉搜索树?二叉搜索树是一种特殊的二叉树,其中每个节点的左子树只包含小于该节点的值,右子树只包含大于该节点的值。

12. 什么是平衡二叉树?平衡二叉树是一种自平衡的二叉搜索树,它通过旋转操作来保持树的平衡,使得树的高度保持在对数级别。

13. 什么是B树?B树是一种自平衡的树数据结构,它保持数据的有序性,并允许搜索、顺序访问、插入和删除的操作都在对数时间内完成。

数据结构试卷试题及答案

数据结构试卷试题及答案

数据结构试卷试题及答案一、选择题(每题5分,共40分)1. 数据结构是研究数据元素的()A. 存储结构B. 处理方法C. 逻辑结构D. 所有以上内容答案:D2. 在数据结构中,通常采用()方式来表示数据元素之间的逻辑关系。

A. 顺序存储结构B. 链式存储结构C. 索引存储结构D. 散列存储结构答案:B3. 下面哪一个不是栈的基本操作?()A. 入栈B. 出栈C. 判断栈空D. 获取栈顶元素答案:D4. 下面哪一个不是队列的基本操作?()A. 入队B. 出队C. 判断队列空D. 获取队头元素答案:D5. 下面哪一个不是线性表的特点?()A. 有且只有一个根节点B. 每个节点最多有一个前驱和一个后继C. 数据元素类型相同D. 数据元素类型可以不同答案:D6. 在下列哪种情况中,使用链式存储结构比顺序存储结构更合适?()A. 数据元素经常插入和删除B. 数据元素大小不固定C. 数据元素个数不确定D. 所有以上情况答案:D7. 下面哪一个不是树的遍历方式?()A. 前序遍历B. 中序遍历C. 后序遍历D. 翻转遍历答案:D8. 在下列哪种情况中,使用散列存储结构比其他存储结构更合适?()A. 数据元素个数较少B. 数据元素查找频繁C. 数据元素插入和删除频繁D. 数据元素大小不固定答案:B二、填空题(每题5分,共30分)9. 栈是一种特殊的线性表,它的插入和删除操作都限定在表的一端进行,这一端称为______。

答案:栈顶10. 队列是一种特殊的线性表,它的插入操作在表的一端进行,这一端称为______,而删除操作在另一端进行,这一端称为______。

答案:队尾、队头11. 二叉树中的节点包括______和______。

答案:根节点、子节点12. 在图的存储结构中,邻接矩阵表示法用______个一维数组来表示图中各个顶点之间的关系。

答案:两个13. 散列存储结构中,关键码到存储地址的映射方法称为______。

《数据结构》期末考试试题及答案

《数据结构》期末考试试题及答案

《数据结构》期末考试试题及答案一、选择题(每题2分,共20分)1. 下列哪种数据结构是线性结构?A. 栈B. 树C. 队列D. 图答案:A2. 在计算机科学中,什么是最基本的数据结构?A. 数组B. 链表C. 栈D. 树答案:C3. 下列哪种操作的时间复杂度是O(1)?A. 在链表中插入元素B. 在数组中查找元素C. 在树中删除节点D. 在图中寻找最短路径答案:B4. 下列哪种数据结构常常用于实现栈和队列?A. 数组B. 链表C. 树D. 图答案:A5. 下列哪种数据结构是有序的?A. 栈B. 队列C. 链表D. 图答案:C二、填空题(每题2分,共20分)1. 在数据结构中,栈是一种后进先出(____)的数据结构。

答案:线性表2. 队列是一种先进先出(____)的数据结构。

答案:线性表3. 链表是一种____数据结构,由一系列节点组成。

答案:非线性4. 二叉树是一种特殊的树,它的每个节点最多有两个____。

答案:子节点5. 哈希表是通过____函数将关键字映射到表中的位置来访问数据。

答案:哈希三、判断题(每题2分,共20分)1. 树是一种线性结构。

()答案:错误2. 链表的插入和删除操作时间复杂度都是O(1)。

()答案:错误3. 图是一种线性结构。

()答案:错误4. 哈希表是一种基于顺序结构的的数据结构。

()答案:错误5. 在数据结构中,时间复杂度O(n)表示算法随着输入规模的增加而线性增长。

()答案:正确四、简答题(每题10分,共30分)1. 请简述栈和队列的特点和应用场景。

答案:栈是一种后进先出(LIFO)的数据结构,应用场景包括函数调用栈、表达式求值等。

队列是一种先进先出(FIFO)的数据结构,应用场景包括任务队列、缓冲区等。

2. 请简述链表的优缺点。

答案:链表的优点包括动态扩容、插入和删除操作时间复杂度为O(1)、可以方便地实现各种复杂数据结构。

缺点包括占用内存空间较大、不如数组支持随机访问。

数据结构考试题及答案

数据结构考试题及答案

数据结构考试题及答案一、选择题1. 下列哪种数据结构是一种线性结构?A. 树B. 栈C. 图D. 队列答案:B. 栈2. 以下哪种不是二叉树的遍历方式?A. 先序遍历B. 层序遍历C. 后序遍历D. 中序遍历答案:B. 层序遍历3. 在队列中,哪种操作不是O(1)时间复杂度的?A. 入队B. 出队C. 判空D. 获取队首元素答案:D. 获取队首元素二、填空题4. 二叉查找树的中序遍历结果为_______。

答案:升序排列的序列5. 栈的特点是_______进,_______出。

答案:后进,先出6. 图中两点间存在边则称它们为_______。

答案:邻接点三、简答题7. 请简要介绍一下栈和队列的应用场景及区别。

答:栈和队列都是常用的数据结构,栈适合用于实现括号匹配、表达式求值等场景,而队列常用于实现广度优先搜索、缓存队列等。

栈是一种后进先出的数据结构,而队列是一种先进先出的数据结构。

8. 什么是哈希表?它的优缺点分别是什么?答:哈希表是一种通过哈希函数将关键字映射到数组位置的数据结构。

其优点是能够快速查找、插入、删除元素,时间复杂度接近O(1);缺点是可能发生哈希冲突,导致性能下降。

四、综合题9. 给定以下无向图的邻接矩阵表示,请写出图的深度优先搜索(DFS)遍历路径。

```0 1 2 30 0 1 0 11 1 0 1 12 0 1 0 13 1 1 1 0```答:起始节点为0,路径:0 - 1 - 3 - 210. 写出以下树的层序遍历结果。

```1/ \2 3/ \ / \4 5 6 7```答:1 - 2 - 3 - 4 - 5 - 6 - 7以上就是数据结构考试题及答案,希望对您有所帮助。

如果有不清楚的地方,欢迎随时向老师询问。

祝您考试顺利!。

数据结构期末考试试卷及答案

数据结构期末考试试卷及答案

数据结构期末考试试卷及答案一、选择题(每题2分,共20分)1. 下列哪一个不是线性结构的特点?A. 有且只有一个根结点B. 每个结点最多有一个前驱和一个后继C. 有多个根结点D. 有且只有一个叶子结点答案:C2. 在单链表中,头结点的作用是()A. 作为链表的起点B. 作为链表的终点C. 存储链表中的数据元素D. 作为链表中的第一个元素答案:A3. 在顺序表中,插入一个元素的时间复杂度是()A. O(1)B. O(n)C. O(logn)D. O(n^2)答案:B4. 下列哪种排序算法的平均时间复杂度最高?A. 冒泡排序B. 快速排序C. 直接插入排序D. 希尔排序答案:C5. 在二叉树中,具有3个结点的二叉树有()种不同的形态。

A. 2B. 3C. 4D. 5答案:C6. 下列哪种情况不适合使用哈希表?A. 查找速度快B. 数据量较大C. 数据量较小D. 数据元素关键字分布均匀答案:C7. 在图的遍历过程中,下列哪种遍历方法属于深度优先遍历?A. 广度优先遍历B. 深度优先遍历C. 混合遍历D. 随机遍历答案:B8. 下列哪种数据结构不适用于实现栈?A. 顺序表B. 链表C. 树D. 图答案:C9. 在双向链表中,删除一个元素的时间复杂度是()A. O(1)B. O(n)C. O(logn)D. O(n^2)答案:A10. 下列哪种情况不适合使用队列?A. 数据元素先进先出B. 数据元素后进先出C. 数据元素随机进出D. 数据元素按顺序进出答案:B二、填空题(每题2分,共20分)1. 线性表是具有______个数据元素的有限序列。

答案:n2. 在单链表中,每个结点包含两个域:数据域和______域。

答案:指针3. 在顺序表中,插入一个元素的时间复杂度是______。

答案:O(n)4. 快速排序的平均时间复杂度为______。

答案:O(nlogn)5. 哈希表中的冲突指的是______。

答案:不同的关键字对应同一存储位置6. 在图的遍历过程中,深度优先遍历算法使用的数据结构是______。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

数据构造综合练习一、选择题1.数据的存储构造包括顺序、、散列和〔〕4种根本类型。

A索引 B数组 C集合 D向量2.下面程序的时间复杂性的量级为〔〕。

int i=0,s1=0,s2=0;while〔i++<n〕{if (i%2)s1+=i;else s2+=i;}A.O(1)B.O(1bn)C.O〔n〕D.O(2n)3.下面程序段的时间复杂度为〔〕。

for(int i=0;i<m;i++)for(int j=0;j<n;j++)a[i][j]=i*j;A.O(m2)B.O(n2)C.O(m+n)D.O(m*n)4.在一个长度为n的顺序存储构造的线性表中,向第i个元素〔1≤ i≤n+1〕位置插入一个元素时,需要从后向前依次后移〔〕个元素。

A.n-iB.n-i+lC.n-i-lD.i5.在一个长度为n的顺序存储构造的线性表中,删除第i个元素〔1≤i≤n+1〕时,需要从前向后依次后移〔〕个元素。

A.n-iB.n-i+lC.n-i-lD.i6.在一个长度为n的线性表中,删除值为*的元素时需要比拟元素和移动元素的总次数为〔〕。

A.(n+1)/2B.n/2C.nD.n+17.在一个顺序表中的任何位置插入一个元素的时间复杂度为〔〕。

A. O(n)B. O(n/2)C. O(1)D. O(n2)8. 线性表的链式存储比顺序存储更有利于进展〔〕操作。

A.查找B.表尾插入和删除C.按值插入和删除D.表头的插入和删除9. 线性表的顺序存储比链式存储更有利于进展〔〕操作。

A.查找B.表尾插入和删除C.按值插入和删除D.表头的插入和删除10. 在一个表头指针为ph的单链表中,假设要向表头插入一个由指针p指向的结点,则应执行〔〕操作。

A. ph=p; p->ne*t=ph;B. p->ne*t=ph; ph=p;C. p->ne*t=ph; p=ph;D. p->ne*t=ph->ne*t; ph->ne*t=p;11. 在一个表头指针为ph的单链表中,假设要在指针q所指结点的后面插入一个由指针p 所指向的结点,则执行〔〕操作。

A. q->ne*t=p->ne*t; p->ne*t=q;B. p->ne*t=q->ne*t; q=p;C. q->ne*t=p->ne*t; p->ne*t=q;D. p->ne*t=q->ne*t; q->ne*t=p;12.在一个单链表HL中,假设要删除由指针q所指向结点的后继结点〔假设存在的话〕,则执行〔〕操作。

A. p=q->ne*t; p->ne*t=q->ne*t;B. p=q->ne*t; q->ne*t=p;C. p=q->ne*t; q->ne*t=p->ne*t;D. q->ne*t=q->ne*t->ne*t; q->ne*t=q;13.栈的插入和删除操作在〔〕进展。

A. 栈顶B. 栈底C. 任意位置D. 指定位置14.假设让元素1,2,3,4依次进栈,则出栈次序不可能出现〔〕的情况。

A.3,2,1,4B.2,1,4,3C.4,3,2,1D.1,4,2,3.15. 假定一个顺序循环队列的队首和队尾指针分别用f和r表示,则判断队空的条件为〔〕。

A.f+1==rB.r+1==fC.f==0D.f==r16. 假定一个顺序循环队列存储于数组a[N],其队首和队尾指针分别用f和r表示,则判断队满的条件为〔〕。

A.〔r-1〕%N==fB.〔r+1〕%N==fC.〔f-1〕%N==rD.〔f+1〕%N==r17. 二维数组A[12,10]采用行优先存储,每个数据元素占用4个存储单元,该数组的首地址〔A[0,0]的地址〕为1200,则A[6,5]的地址为〔〕。

A.1400B.1404C.1372D.146018.在一棵具有n个结点的二叉树中,所有结点的空子树个数等于〔〕。

A.nB.n-1C.n+1D.2n19.有如图1所示的一棵二叉树,则该二叉树的中序遍历序列为〔〕。

A. ABCDEFGB. CDBGFEAC. CBDAEGFD. ABECDFG20.有如图1所示的一棵二叉树,则该二叉树的先序遍历序列为〔〕。

A.ABCDEFGB.CDBGFEAC.CBDAEGFD.ABECDFG21.有如图1所示的一棵二叉树,则该二叉树的后序便利序列为〔〕。

A.ABCDEFGB.CDBGFEAC.CBDAEGFD.ABECDFG22.利用n个值生成的哈夫曼树中共有〔〕个结点。

A.nB.n+1C.2nD.2n-123.利用3,6,8,12这4个值作为叶子结点的权,生成一棵哈夫曼树,该树的带权路径长度为〔〕。

A.55B.29C.58D.3824.在一个具有n个顶点的无向图中,假设具有e条边,则所有顶点的度数为〔〕。

A.nB.eC.n+eD.2e25.在一个具有n个顶点和e条边的无向图的邻接矩阵中,表示边存在的元素〔又称为有效元素〕的个数为〔〕。

A.nB.neC.eD.2e26.假设一个图的边集为{〔A,B〕〔A,C〕〔B,D〕〔C,F〕〔D,E〕〔D,F〕},则从顶点A 开场对该图进展深度优先搜索,得到的顶点序列可能为〔〕。

A. ABCFDEB. ACFDEBC. ABDCFED. ABDFEC27.假设一个图的边集为{〔A,B〕〔A,C〕〔B,D〕〔C,F〕〔D,E〕〔D,F〕},则从顶点A 开场对该图进展广度优先搜索,得到的顶点序列可能为〔〕。

A.ABCDEFB.ABCFDEC.ABDCEFD.ACBFDE28.对于顺序存储的有序表〔5,12,20,26,37,42,46,50,64〕,假设采用二分查找,则查找元素26的查找长度为〔〕。

A.2B.3C.4D.529.假设根据查找表〔23,44,36,48,52,73,64,58〕建立线性哈希表,采用H〔K〕=K%13计算哈希地址,则元素64的哈希地址为〔〕。

A.4B.8C.12D.1330.假设根据查找表〔23,44,36,48,52,73,64,58〕建立线形哈希表,采用H〔K〕=K%13计算哈希地址,则哈希地址为3的元素个数为〔〕。

A.1B.2C.3D.4 答案为031.假设一个元素序列根本有序,则选用〔〕方法较快。

A.直接插入排序B.简单项选择择排序C.堆排序D.快速排序二﹑填空题1.数据的逻辑构造可分为_ ___和_ ___两大类。

线性;非线性2.数据的存储构造被分为____,_____,_____和____4种。

顺序;链式;索引;散列存储构造3.一种数据构造的元素集合K和它的二元关系R为:K={a,b,c,d,e,f,g,h}R={<a,b>,<b,c>,<c,d>,<d,e>,<e,f>,<f,g>,<g,h>}则该数据构造具有____构造。

线性4.一种数据构造的元素集合K和它的二元关系R为: K={a,b,c,d,e,f,g,h}R={<d,b>,<d,g>,<b,a>,<b,c>,<g,e>,<g,h>,<e,f>}则该数据构造具有____构造。

非线性5.线性表的两种存储构造分别为____和____。

顺序;链式6.在一个单链表中删除指针p所指向结点的后继结点时,需要把____ 的值赋给p->ne*t指针域。

.p->ne*t->ne*t7.栈又称为____表,队列又称为____表。

先进后出;先进先出8.假定一个链栈的栈顶指针为top,每个结点包含值域data和指针域ne*t,当p所指向的结点入栈时,则首先执行____操作,然后执行____操作。

.p->ne*t=top;top=pABCE图 2DGIHF9.队列的插入操作在____进展,删除操作在____进展。

队尾;对头10.在一棵二叉树中,假定双分支结点数为5个,单分支结点数为6个,则叶子结点数为____。

611.对于一棵二叉树,假设一个结点的编号i,假设它的左孩子结点存在,则其编号为____,假设右孩子结点存在,则其编号为____,假设双亲结点存在,则其编号为____。

2i;2i+1;i/212.一个森林转换成二叉树后如图1.9所示,则该森林中包含____棵树。

313.假设由3,6,8,12,10作为叶子结点的值生成一棵哈夫曼树,则该树的深度为____,带权路径长度为____。

4;8714.一种数据构造的元素集合K和它的二元关系R为:K={1,2,3,4,5,6}R={〔1,2〕〔2,3〕〔2,4〕〔3,4〕〔3,5〕〔3,6〕〔4,5〕〔4,6〕}则该数据构造具有____数据构造。

图状15.假定对线性表〔38,25,74,52,48〕,进展散列存储,采用H〔K〕=K%7作为哈希函数,采用线性探测再散列法处理冲突,则在建立哈希表过程中,将会碰到_____次冲突,平均查找长度为______。

5;216.假设对一组记录〔46,79,56,38,40,80,35,50,74〕进展直接插入排序,当把第8个记录插入到前面已排序的有序表时,为寻找插入位置需比拟_____次。

4三、简答题1. 一棵二叉树的中序遍历序列为CDBAEGF,先序遍历序列为 ABCDEFG,试问能不能唯一确定一棵二叉树?假设能,画出该二叉树。

假设给定先序遍历序列和后序遍历序列,能否唯一确定?18.(1)由中序遍历序列和先序遍历序列,或中序遍历序列和后序遍历序列,可以唯一确定一颗二叉树。

由先序序列知,根结点最先被访问,就可确定根结点为A,而又由中序序列得知一棵树的根结点是其左,右子树的分隔点,从而可确定以A 为根的左子树的结点为B,C,D,右子树的结点为E,F,G。

重复进展就可得到二叉树。

〔2〕由先序遍历序列和后序遍历序列不能唯一确定一棵二叉树。

因为两种遍历方法只能确定根结点,而分不清左右子树。

2.将图1.12所示的树转换成二叉树。

3.试分别画出具有3个结点的树和3 个结点的二叉树的所有不同形态。

树的状态如图1.21 所示.3 个结点的二叉树的状态如图1.22 所示4.假定用于通信的电文由8个字母组成,分别是A,B,C,D,E,F, G,和H,各字母在电文中出现的概率为:5%,25%,4%,7%,9%,12%,30%,8%,试为8个字母设计哈夫曼编码。

5.给出一组关键字〔19,01,26,92,87,11,43,87,21〕,进展冒泡排序,列出每一遍排序后关键字的排列次序,并统计每遍排序进展的关键字比拟次数。

相关文档
最新文档