数据结构期末复习资料

合集下载

数据结构期末考试复习题资料

数据结构期末考试复习题资料

数据结构期末考试复习题资料一.单项选择题1.算法指的是()。

A.计算方法B.排序方法C.特定问题求解步骤的描述D.调度方法2.下列数据结构中,()是非线性结构。

A.栈B.队列C.完全二叉树D.堆3.若某线性表最常用的操作是存取任一指定序号的元素和在最后进行插入和删除运算,则利用()存储方式最节省时间。

A.顺序表B.双向链表C.单循环链表D.带头结点的双循环链表4.队列的操作原则是()A.先进先出B.后进先出C.先进后出D.不分顺序5.栈和队列的共同特点是()。

A.都是先进先出B.都是先进后出C.都是只允许在端点处插入和删除D.没有共同点6.在一棵高度为k 的满二叉树中,结点总数为()。

A.2k-1 B.2k C.2k-1 D.⎣log 2 k ⎦+ 17.在下列存储形式中,哪一个不是树的存储形式?()A.双亲链表表示法B.孩子链表表示法C.孩子兄弟链表表示法D.顺序存储表示法8.n 个结点的完全有向图含有边的数目为()。

A.n*n B.n*(n+1) C.n/2 D.n*(n-1)9.n 个顶点的强连通图至少有()条边。

A.n B.n-1 C.n+1 D.n(n-1)10、高度为k 的二叉树的最大结点数为()。

A、2kB、2k-1C、2k–1D、2k-1–111、下列哪一种图的邻接矩阵是对称矩阵?()A、有向图B、无向图C、AOV 网D、AOE 网12、在下列存储形式中,哪一个不是树的存储形式?()A、双亲表示法B、孩子表示法C、孩子兄弟表示法D、顺序存储表示法13、下面哪一方法可以判断出一个有向图是否有环。

()A、深度优先遍历B、拓扑排序C、求最短路径D、广度优先遍历14.适用于折半查找的表的存储方式及元素排列要求为()。

A.链接方式存储,元素无序B.链接方式存储,元素有序C.顺序方式存储,元素无序D.顺序方式存储,元素有序15、一个算法应该是()。

A、程序B、特定问题求解步骤的描述C、要满足五个基本特性D、A 和C16、算法分析的两个主要方面是()。

数据结构期末复习总结

数据结构期末复习总结

第1章绪论1.数据(Data) :是描述客观事物的数字、字符以及所有能输入到计算机中并能被计算机接受的各种符号集合的统称。

包括数值数据和非数值数据(字符串、图形、图像、音频、视频)。

2.数据元素(Data Element) :表示一个事物的一组数据称为一个数据元素(结点顶点、记录);数据元素是数据的基本单位。

3.数据项(Data Item):是数据元素中有独立含义的、不可分割的最小标识单位(字段、域、属性)。

一个数据元素可由若干个数据项组成。

4.数据对象(Data Object):是性质相同的数据元素的集合,是数据的一个子集。

如字符集合C ={A,B,C,…} 。

数据(Data) :是描述客观事物的数字、字符以及所有能输入到计算机中并能被计算机接受的各种符号集合的统称。

包括数值数据和非数值数据(字符串、图形、图像、音频、视频)。

数据元素(Data Element) :表示一个事物的一组数据称为一个数据元素(结点、顶点、记录);数据元素是数据的基本单位。

数据项(Data Item):是数据元素中有独立含义的、不可分割的最小标识单位(字段、域、属性)。

一个数据元素可由若干个数据项组成。

数据对象(Data Object):是性质相同的数据元素的集合,是数据的一个子集。

如字符集合C ={A,B,C,…} 。

●数据的逻辑结构指数据元素之间的逻辑关系,用一个数据元素的集合和定义在此集合上的若干关系来表示。

●四种逻辑结构:集合、线性结构、树型结构、图状结构。

●数据结构的形式定义是一个二元组:Data-Structure=(D,S)其中:D是数据元素的有限集,S是D上关系的有限集。

例1:设数据逻辑结构B=(K,R)K={k1, k2, …, k9}R={ <k1, k3>,<k1, k8>,<k2, k3>,<k2, k4>,<k2, k5>,<k3, k9>,<k5, k6>,<k8, k9>,<k9, k7>,<k4, k7>,<k4, k6>有时候关系图不唯一(一般是无向图)●数据结构在计算机内存中的存储包括数据元素的存储和元素之间的关系的表示。

数据结构复习资料

数据结构复习资料

数据结构复习资料一、数据结构的基本概念数据结构是指相互之间存在一种或多种特定关系的数据元素的集合。

它不仅要考虑数据元素的存储,还要关注数据元素之间的关系以及对这些数据的操作。

数据元素是数据的基本单位,例如整数、字符、字符串等。

而数据项则是数据元素的最小不可分割的部分。

常见的数据结构类型包括线性结构(如数组、链表、栈和队列)、树形结构(如二叉树、二叉搜索树、AVL 树等)、图形结构等。

二、线性结构1、数组数组是一组具有相同数据类型的元素的有序集合。

它的优点是可以通过下标快速访问元素,但插入和删除操作可能比较低效,因为需要移动大量元素。

2、链表链表由一系列节点组成,每个节点包含数据和指向下一个节点的指针。

链表的插入和删除操作相对简单,但访问特定元素需要遍历链表。

3、栈栈是一种特殊的线性表,遵循后进先出(LIFO)原则。

入栈和出栈操作是栈的基本操作。

4、队列队列遵循先进先出(FIFO)原则,入队和出队操作是队列的主要操作。

三、树形结构1、二叉树二叉树是每个节点最多有两个子节点的树形结构。

它有满二叉树、完全二叉树等特殊形式。

2、二叉搜索树二叉搜索树的左子树的所有节点值小于根节点值,右子树的所有节点值大于根节点值。

这使得查找、插入和删除操作的平均时间复杂度为 O(log n)。

3、 AVL 树AVL 树是一种自平衡的二叉搜索树,通过旋转操作保持树的平衡,从而保证查找、插入和删除的时间复杂度始终为 O(log n)。

四、图形结构图形由顶点和边组成,可以分为有向图和无向图。

常见的算法包括深度优先搜索和广度优先搜索,用于遍历图形。

五、数据结构的操作对于不同的数据结构,常见的操作包括创建、插入、删除、查找、遍历等。

1、插入操作根据数据结构的特点,选择合适的位置插入新元素。

2、删除操作准确找到要删除的元素,并处理删除后的结构调整。

3、查找操作利用数据结构的特性,提高查找效率。

4、遍历操作如前序遍历、中序遍历、后序遍历对于二叉树;深度优先遍历和广度优先遍历对于图形。

数据结构 期末复习

数据结构    期末复习

第30页
将一棵树转换为二叉树的方法:
⑴ 树中所有相邻兄弟之间加一条连线。 ⑵ 对树中的每个结点,只保留其与第一个孩子结点之间的 连线,删去其与其它孩子结点之间的连线。 ⑶ 以树的根结点为轴心,将整棵树顺时针旋转一定的角度, 使之结构层次分明。
A A B E E F G E F G F C D A D
NK
K N L
LM
M
第28页
1、该二叉树结点的前序遍历的序列为( C)。 A. E、G、F、A、C、D、B B. E、A、G、C、F、B、D C. E、A、C、B、D、G、F D. E、G、A、C、D、F、B
2、该二叉树结点的中序遍历的序列为( A)。
A. A、B、C、D、E、G、F B. E、A、G、C、F、B、D C. E、A、C、B、D、G、F D. D、C、A、F、G、E
B
C
D
B
C
H
H
H
G
2. 森林转换为二叉树
森林转换为二叉树的方法为: (1)将森林中的每棵树转换成相应的二叉树。 (2)第一棵二叉树不动,从第二棵二叉树开始,依次把后 一棵二叉树的根结点作为前一棵二叉树根结点的右孩子,当 所有二叉树连在一起后,所得到的二叉树就是由森林转换得 到的二叉树。
第32页
森林转换为二叉树的过程
A C
A
B C D F H I J E G B C D
A
E F H I J G
G D F
B
H
I J
第35页
例、设森林F中有三棵树,第一、第二和第三棵树的结点个数 分别为M1、M2和M3。与森林F对应的二叉树根结点的右子树上 的结点个数是:
A)M1 B)M1+M2 C)M3 D)M2+M3

数据结构期末重点复习必过

数据结构期末重点复习必过

数据结构期末重点复习必过1.1 简述下列概念:数据、数据元素、数据类型、数据结构、逻辑结构、存储结构、线性结构、非线性结构。

◆ 数据:指能够被计算机识别、存储和加工处理的信息载体。

◆ 数据元素:就是数据的基本单位,在某些情况下数据项组成。

◆ 数据类型:是一个值的集合以及在这些值上定义的一组操作的总称。

◆ 数据结构:指的是数据之间的相互关系,即数据的组织形式。

一般包括三个方面的内容:数据的逻辑结构、存储结构和数据的运算。

◆ 逻辑结构:指各数据元素之间的逻辑关系。

◆ 存储结构:就是数据的逻辑结构用计算机语言的实现。

◆ 线性结构:数据逻辑结构中的一类,它的特征是若结构为非空集,则该结构有且只有一个开始结点和一个终端结点,并且所有结点都最多只有一个直接前趋和一个直接后继。

线性表就是一个典型的线性结构。

◆ 非线性结构:数据逻辑结构中的另一大类,它的逻辑特征是一个结点可能有多个直接前趋和直接后继。

1.2 试举一个数据结构的例子、叙述其逻辑结构、存储结构、运算三个方面的内容。

◆例如有一张学生成绩表,记录了一个班的学生各门课的成绩。

按学生的姓名为一行记成的表。

这个表就是一个数据结构。

每个记录(有姓名,学号,成绩等字段)就是一个结点,对于整个表来说,只有一个开始结点(它的前面无记录)和一个终端结点(它的后面无记录),其他的结点则各有一个也只有一个直接前趋和直接后继(它的前面和后面均有且只有一个记录)。

这几个关系就确定了这个表的逻辑结构。

那么我们怎样把这个表中的数据存储到计算机里呢? 用高级语言如何表示各结点之间的关系呢?是用一片连续的内存单元来存放这些记录(如用数组表示)还是随机存放各结点数据再用指针进行链接呢?这就是存储结构的问题,我们都是从高级语言的层次来讨论这个问题的。

(所以各位赶快学C语言吧)。

最后,我们有了这个表(数据结构),肯定要用它,那么就是要对这张表中的记录进行查询,修改,删除等操作,对这个表可以进行哪些操作以及如何实现这些操作就是数据的运算问题了。

数据结构期末考试重点复习资料

数据结构期末考试重点复习资料

期末考试重点复习资料二、考试重点内容第一章绪论1、时间复杂度和空间复杂度的计算。

要求能够计算出程序的执行次数。

2、各种概念:数据结构、数据项、数据元素第二章线性表1、单链表的各种操作,包括单链表的建立、插入、删除结点的操作语句序列2、单链表(带头结点、不带头结点、循环单链表)的逆置运算。

3、双链表的插入和删除操作语句序列。

4、单链表的直接插入排序运算。

5、静态单链表的插入和删除操作。

6、二个有序单链表的合并、一个单链表拆分为多个单链表第三章栈和队列1、栈的输入序列和输出序列、递归函数的输出结果2、循环队列的入队、出队操作以及有效元素个数的计算第四章串1、KMP算法中的next和nextval值的计算第五章数组和广义表1、二维数组任意元素地址的计算2、稀疏矩阵的转置算法3、广义表的两个操作函数:取表头和表尾第六章树和二叉树1、二叉树的性质(特别是完全二叉树的性质,例如求完全二叉树的深度等)2、二叉树的遍历(特别是中序和先序遍历,要求能够使用堆栈完成非递归遍历编程和递归算法编程,在遍历基础上的各种操作,例如求二叉树的叶子数、二叉树结点数等操作,包括有编程算法和编程填空题)3、线索二叉树(特别是中序线索化二叉树和中序线索化二叉树的中序遍历,包括编程算法和编程填空题,希望大家着重研究)4、哈夫曼编码(主要是应用题,包括哈夫曼的编码与解码,也包括哈夫曼树的特点)5、树与森林在转化成二叉树时,左右子树的结点数有何特点)6、树的层次遍历(使用队列完成、借助树的层次遍历可以判断二叉树是否为完全二叉树)、判断二叉树是否为排序二叉树等,可能有编程题或编程填空题)补充:二叉树的物理存储结构(链式和顺序存储)*第七章图1、图的两种物理存储方式(邻接矩阵与邻接表存储表示)2、图的生成树与最小生成树(生成树特点)、图的遍历3、求最小生成树的两种算法(重点是PRIM 算法,特别会写出用PRIM算法求最小生成树的过程)4、使用迪杰斯特拉算法求单源最短路径,写出求解过程5、拓扑排序6、求关键路径,要求写出事件和活动的最早和最晚开始时间,深刻理解关键路径的含义。

数据结构复习资料(亲自整理)

数据结构复习资料(亲自整理)数据结构复习资料(亲自整理)引言:数据结构是计算机科学中的重要基础知识,掌握良好的数据结构能够提高程序的运行效率,同时也是进行算法设计和优化的关键。

本文将为大家提供一份亲自整理的数据结构复习资料,旨在帮助读者回顾和巩固数据结构的知识,并提供一些实践经验和应用场景。

一、数据结构的概念和基本知识1.1 数据结构的定义数据结构是指数据元素之间的相互关系和组织形式,它包括线性结构、树形结构、图形结构等多种形式。

数据结构可以用来描述程序的运行状态和过程中产生的数据,是程序设计的基础。

1.2 常见的数据结构类型介绍常见的数据结构类型,如数组、链表、栈、队列、树、图等,并分别阐述它们的特点、适用场景和基本操作。

1.3 数据结构的时间复杂度和空间复杂度分析详细解释时间复杂度和空间复杂度的概念,分析不同数据结构及其操作的时间和空间复杂度,并通过实例演示如何计算和评估复杂度。

二、线性结构2.1 数组(Array)介绍数组的定义和基本操作,包括初始化、插入、删除、查找等操作。

通过示例展示如何使用数组解决实际问题,并探讨数组的优缺点及应用场景。

2.2 链表(Linked List)介绍链表的概念和分类,包括单向链表、双向链表和循环链表。

详细说明链表的插入、删除和查找操作,并讨论链表的优缺点及适用场景。

2.3 栈(Stack)解释栈的概念和特点,包括栈的基本操作(push、pop、top等)。

演示如何使用栈来解决实际问题,如逆序输出、括号匹配等,同时介绍栈的应用领域。

2.4 队列(Queue)描述队列的定义和基本操作(enqueue、dequeue等),并通过实例介绍队列的应用,如打印任务调度、消息传递等。

三、树形结构3.1 二叉树(Binary Tree)解释二叉树的定义和性质,包括满二叉树、完全二叉树和二叉查找树等。

介绍二叉树的遍历方式(前序、中序、后序)和常见操作,并给出实际应用案例。

3.2 堆(Heap)介绍堆的概念和特点,包括最大堆、最小堆和堆排序。

数据结构期末复习要点

数据结构期末复习要点第一章绪论1、数据结构主要包括哪三方面内容?2、什么是逻辑结构?什么是存储结构?两者有何关系?3、数据的逻辑结构主要分为哪几类?4、存储结构主要有那些方式?5、顺序存储方式是如何表示数据元素之间的关系?其存储地址一定连续吗?6、链式存储方式是如何表示数据元素之间的关系?其存储地址一定连续吗?7、逻辑结构与具体计算机有关吗?存储结构呢?8、什么是抽象数据类型?其主要特征是什么?9、算法与具体的计算机及计算机语言有关吗?10、算法与程序有何关联?11、算法分析主要从哪些方面考虑?12、常用算法复杂度的有哪些数量级别?(按递增排列)第二章线性表1、线性结构的逻辑关系是什么?2、顺序表是如何表示数据元素的逻辑关系的?3、顺序表如何定义数据类型?(计算存储地址)4、单链表带头结点与无头结点的操作比较有什么优势?举例说明。

5、单链表的操作特点是什么?单链表如何定义数据类型?6、循环链表的操作特点是什么?7、双向链表的操作特点是什么?双向链表如何定义数据类型?8、顺序表与链表比较各自的优缺点是什么?第三章栈、队列1、栈的操作原则是什么?2、两个栈共享空间时基本运算如何实现? (判断空或满的条件)3、递归与栈有何关系?递归算法有何优缺点?4、队列的操作原则是什么?5、顺序队列操作中的“假溢出”是什么?如何解决?6、循环队列是存储在循环链表中吗?7、循环队列的操作时如何判空、满以及求长度?8、栈和队列的共同点和不同点是什么?第四章串1、串的逻辑结构是什么?2、空串与空格串的区别是什么?3、两个串相等的充分必要条件是什么?4、什么是串的模式匹配?5、KMP改进算法的最大特点是什么?(求next[])第五章数组和广义表1、数组的逻辑结构是什么?2、数组的特点是什么?数组可以进行插入删除操作吗?3、数组通常以什么方式存储?多维数组存储常用哪两种排列方式?(计算存储地址)4、特殊矩阵的压缩存储基本思想是什么?5、对称矩阵、三角矩阵和对三角矩阵如何压缩存储?(画出压缩存储方式,计算存储地址)6、稀疏矩阵只需存储非零元素的值吗?(画出三元组表和十字链表的存储结构。

计算机-《数据结构》复习资料

《数据结构》复习资料1一、选择题1. 一棵二叉树中第6层上最多有()个结点。

A. 2B. 31C. 32D. 642. 顺序表中数据元素的存取方式为()。

A. 随机存取B. 顺序存取C. 索引存取D. 连续存取3. 设有无向图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)}。

对G进行深度优先遍历,正确的遍历序列是()。

A. a,b,e,c,d,fB. a,c,f,e,b,dC. a,e,b,c,f,dD. a,e,d,f,c,b4. 在待排元素序列基本有序的前提下,效率最高的排序方法是()。

A. 插入B. 选择C. 快速D. 归并5. 设表中含100个数据元素,用折半查找法进行查找,则所需最大比较次数为()。

A. 50B. 25C. 10D. 76. 设哈希表地址范围为0~19,哈希函数H(key)=key%17,使用二次探测再散列法处理冲突。

若表中已存放有关键字值为6、22、38、55的记录,则再放入关键字值为72的记录时,其存放地址应为()。

A. 2B. 3C. 4D. 7E. 8F. 以上都不对7. 设对下图从顶点a出发进行深度优先遍历,则()是可能得到的遍历序列。

A. acfgdebB. abcdefgC. acdgbefD. abefgcd8. 若需在O(nlog2n)的时间内完成对数组的排序,且要求排序是稳定的,则可选择的排序方法是()。

A. 快速排序B. 堆排序C. 归并排序D. 直接插入排序9. 设有一组关键字值(46,79,56,38,40,84),则用堆排序的方法建立的初始堆为()。

A. 79,46,56,38,40,84B. 84,79,56,38,40,46C. 84,79,56,46,40,38D. 84,56,79,40,46,3810. 设广义表L=((a,()),b,(c,d,e)),则Head(Tail(Tail(L)))的值为()。

数据结构总复习

数据结构总复习一、基本概念1. 数据结构的定义及分类2. 算法的基本概念和特性3. 数据结构与算法的关系二、线性表1. 顺序表的实现和应用2. 链表的实现和应用3. 栈的实现和应用4. 队列的实现和应用三、树结构1. 二叉树的定义和性质2. 二叉树的遍历算法3. 二叉树的存储结构和应用4. 线索二叉树的实现和应用5. Huffman树及其应用四、图结构1. 图的基本概念和术语2. 图的存储结构3. 图的遍历算法4. 最小树算法5. 最短路径算法五、查找算法1. 顺序查找2. 二分查找3. 哈希查找六、排序算法1. 冒泡排序2. 插入排序3. 选择排序4. 快速排序5. 归并排序6. 堆排序7. 基数排序七、高级数据结构1. 并查集2. 图的应用:拓扑排序、关键路径算法3. B树与B+树的概念4. 红黑树的定义和性质5. AVL树的定义和性质八、算法分析1. 最坏情况、平均情况和最好情况复杂度分析2. 时间复杂度和空间复杂度计算方法3. 常见算法的时间复杂度比较4. 算法效率的优化策略九、附件:示例代码1. 顺序表代码示例2. 链表代码示例3. 栈代码示例4. 队列代码示例5. 二叉树代码示例6. 图代码示例7. 查找算法代码示例8. 排序算法代码示例9. 高级数据结构代码示例10. 算法分析代码示例法律名词及注释:1. 数据结构:在计算机中组织和存储数据的方式和方法。

2. 算法:解决问题的步骤和方法。

3. 顺序表:采用顺序存储结构的线性表。

4. 链表:采用链式存储结构的线性表。

5. 栈:一种特殊的线性表,只能在一端进行插入和删除操作。

6. 队列:一种特殊的线性表,只能在一端进行插入操作,另一端进行删除操作。

7. 二叉树:每个节点最多有两个子节点的树结构。

8. 图:由顶点和边构成的非线性结构。

9. 哈希查找:利用哈希函数将关键字和存储位置一一对应的查找方法。

10. 冒泡排序:通过相邻元素之间的比较和交换来实现排序的算法。

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

第一章1、数据结构是一门研究非数值计算的程序设计问题中计算机的操作对象以及它们之间的关系和操作等的学科。

数据结构(Data Structure):相互之间存在一种或多种特定关系的数据元素的集合。

2、数据结构的形式定义:二元组Data_Structure=(D,S) 其中,D 是数据元素的有限集,S 是D 上关系的有限集。

3、数据元素之间关系的映像:1、顺序映像(顺序存储结构):以相对的存储位置表示后继关系。

2、非顺序映像(链式存储结构):借助指针元素存储地址的指针表示数据元素之间的逻辑关系。

任何一个算法的设计取决于数据(逻辑)结构,其实现取决于物理结构。

4、 算法的定义:对特定问题求解步骤的一种描述,它是指令的有限序列,其中每一条指令表示一个或多个操作。

特性:有穷性、确定性、可行性、输入、输出5、 算法的评价——衡量算法优劣的标准正确性(correctness):满足具体问题的需求可读性(readability):易读、易理解健壮性(robustness):当输入数据非法时,算法能够做出反应或进行处理效率与低存储量:执行时间短、存储空间小第二章 1、线性表是一种最简单的线性结构。

线性结构 是一个数据元素的有序(次序)关系特点:存在唯一的一个“第一个”的数据元素;存在唯一的一个“最后一个”的数据元素;除第一个数据元素外,均有唯一的前驱;除最后一个数据元素外,均有唯一的后继2、线性表类型的实现——顺序映像 定义:用一组地址连续的存储单元依次存放线性表中的数据元素。

⏹ 以“存储位置相邻”表示有序对<ai -1,ai >,则有:LOC (ai ) = LOC (ai -1) + l 其中l 是一个数据元素所占存储量LOC (ai ) = LOC (a 1) + (i -1)×l⏹ 特点:1、实现逻辑上相邻—物理地址相邻2、实现随机存取3、若假定在线性表中任何一个位置上进行插入的概率都是相等的,则移动元素的期望值为:∑+=+-+=11)1(11n i is i n n E 2n = 若假定在线性表中任何一个位置上进行删除的概率都是相等的,则移动元素的期望值为:∑=-=n i dl i n n E 1)(121-=n 4、 线性表类型的实现——链式映像 线性链表 特点:用一组地址任意的存储单元存放线性表中的数据元素。

5、在单链表中第 i 个结点之前进行插入的基本操作为:找到线性表中第i-1个结点,然后修改其指向后继的指针。

s = (LinkList) malloc ( sizeof (LNode)); // 生成新结点s->data = e; s->next = p->next; p->next = s; // 插入在单链表中删除第 i 个结点的基本操作为:找到线性表中第i-1个结点,修改其指向后继的指针。

q = p->next; p->next = q->next; e = q->data; free(q);5、 循环链表:最后一个结点的指针域的指针又指回第一个结点的链表。

和单链表的差别仅在于: 判别链表中最后一个结点的条件不再是“后继是否为空”,而是“后继是否为头结点”。

6、 双向链表的操作特点:1、“查询” 和单链表相同;2、“插入” 和“删除”时需要同时修改两个方向上的指针“插入”:s->next = p->next; p->next = s; s->next->prior = s; s->prior = p;(s是插入的结点)删除:p->next = p->next->next; p->next->prior = p;(要删除的是p的下一个结点)第三章1、栈、队列的特点:☐从数据元素间的逻辑关系看◊是线性表☐从操作方式与种类看◊不同于线性表:栈与队列是操作受限的线性表2、栈的基本概念栈---是限制仅在线性表的一端进行插入和删除运算的线性表。

栈顶(TOP)--允许插入和删除的一端。

栈底(bottom)--不允许插入和删除的一端。

空栈--表中没有元素。

栈--又称为后进先出的线性表3、栈中元素的特性:1、具有线性关系2、后进先出4、栈的进栈出栈规则:a)按序进栈:有n个元素1,2,…,n,它们按1,2, …, n的次序进栈(i进栈时,1~(i-1)应该已经进栈);b)栈顶出栈:栈底最后出栈;c)时进时出:元素未完全进栈时,即可出栈。

5、栈的表示与实现顺序栈即栈的顺序存储结构:一组地址连续的存储单元依次存放自栈底到栈顶的数据元素。

1、附设一个栈底指针base,总是指向栈底。

2、附设一个栈顶指针top。

空栈时,top=base;非空栈时,总是指向栈顶元素+1的位置。

☐插入一个栈顶元素,指针top增1;☐删除一个栈顶元素,指针top减1;☐非空栈中的栈顶指针始终在栈顶元素的下一个位置上链栈:注意: 链栈中指针的方向指向前驱结点!6、队列⏹队列:只允许在表的一端进行插入,而在表的另一端进行删除的线性表。

☐队尾(rear)——允许插入的一端☐队头(front)——允许删除的一端⏹队列特点:先进先出(FIFO)7、队列类型的实现⏹链队列——队列的链式表示和实现⏹顺序队列——队列的顺序表示和实现用一组连续的存储单元依次存放队列中的元素8、顺序队列运算时的头、尾指针变化设两个指针front,rear,约定:rear指示队尾元素;front指示队头元素前一位置初值front=rear=0空队列条件:Q.front==Q.rear队列满:Q.rear-Q.front=m入队列:Q.base[rear++]=x;出队列:x=Q.base[++front];存在问题:设数组维数为M,则:⏹当rear-front=m时,再有元素入队发生溢出——真溢出⏹当rear已指向队尾,但队列前端仍有空位置时,再有元素入队发生溢出——假溢出!9、循环队列:将数组首尾相接(即:base[0]连在base[m-1]之后)。

入/出队列运算利用“模运算”,则:➢入队:Q.rear=(Q.rear+1)%m➢出队:Q.front=(Q.front+1)%m队满和队空判断条件:少用一个元素空间:队空:Q.rear=(Q.front)队满:(Q.rear+1)%m=Q.front10、栈和队列是限定插入和删除只能在表的“端点”进行的线性表。

a)栈具有“后进先出”的特性;b)队列具有“先进先出”的特性。

11、栈的链式存储不需头结点。

课后作业1.简述以下算法的功能(栈和队列的元素类型均为int)void algo3 (Queue &Q){Stack S; int d;InitStack(S);while (!QueueEmpty(Q)){DeQueue(Q, d); Push(S, d);}while (!StackEmpty(S)){Pop(S, d); EnQueue(Q, d);}}第六章本章小结⏹二叉树的结构特性,各性质相应的证明方法。

⏹二叉树的各种存储结构的特点及适用范围。

⏹遍历二叉树是二叉树各种操作的基础,遍历的具体算法与所采用的存储结构有关。

⏹树和森林与二叉树的转换。

⏹最优二叉树的特性,掌握建立最优树和哈夫曼编码的方法。

-、树的定义1、树型结构:(非线性结构)至少存在一个数据元素有两个或两个以上的直接前驱(或直接后继)元素的数据结构。

树的定义:是n(n≥0)个结点的有限集合T,对于任意一棵非空树,它满足:有且仅有一个特定的称为根(root)的结点;当n>1时,其余结点可分为m(m>0)个互不相交的有限集T1,T2,….,T m,其中每个集合本身又是一棵树,称为根的子树。

上述树的定义是一个递归定义。

2、基本术语结点:包含一个数据元素及若干指向其子树的分支。

结点的度:结点拥有的子树数。

叶子(或终端)结点:度为零的结点。

分支(或非终端)结点:度大于零的结点树的度:树中所有结点的度的最大值结点的层次:根结点的层次为1,第l层的结点的子树的根结点的层次为l+1。

树的深度:树中叶子结点所在的最大层次。

任何一棵非空树是一个二元组Tree = (root,F)其中:root 被称为根结点F 被称为子树森林二、二叉树1、二叉树的定义是n(n>=0)个结点的有限集合,它或为空树(n=0),或由一个根结点和至多两棵称为根的左子树和右子树的互不相交的二叉树组成。

注:二叉树中不存在度大于2的结点,并且二叉树的子树有左子树和右子树之分。

2、二叉树的五种基本形态:空树只含根结点右子树为空树左子树为空树左右子树均不为空树3、二叉树的性质性质1 :在二叉树的第i层上至多有2i-1个结点(i≥1)。

其中2i-1为2的i-1次方性质2:深度为k 的二叉树上至多含2k-1个结点(k≥1)。

其中2k-1为2的k次方减一性质3:对任何一棵二叉树,若它含有n0个叶子结点、n2个度为2的结点,则必存在关系式:n0 = n2+1。

证明:设二叉树上结点总数n = n0 + n1 + n2,∵二叉树上分支总数b = n1+2n2,①而 b = n-1 = n0 + n1 + n2–1 ②由①②,n0 = n2 + 1。

除根结点外,其余结点都有一个分支进入,设b为分支总数,则n=b+1性质4:具有n个结点的完全二叉树的深度为⎣ log2n⎦+1。

其中⎣ log2n⎦为不大于log2n的最大整数性质5:若对含n个结点的完全二叉树从上到下且从左至右进行 1 至n的编号,则对完全二叉树中任意一个编号为i的结点:(1)若i=1,则该结点是二叉树的根,无双亲,否则,编号为⎣i/2⎦的结点为其双亲结点;(2)若2i>n,则该结点无左孩子,否则,编号为2i的结点为其左孩子结点;(3)若2i+1>n,则该结点无右孩子结点,否则,编号为2i+1 的结点为其右孩子结点。

4、两类特殊的二叉树:满二叉树:指的是深度为k且含有2k-1个结点的二叉树。

其中2k-1为2的k次方减一特点:是每一层上的结点数都是最大结点数。

完全二叉树:树中所含的n 个结点和满二叉树中编号为1至n 的结点一一对应。

特点:⑴叶子结点只可能在层次最大的两层出现;⑵对任一结点,若其右分支下的子孙的最大层次为l,则其左分支下的子孙的最大层次为l或l+1。

性质练习:1. 一棵二叉树在其第五层中有17个结点,可不可能?第i层上至多有2i-1个结点,则25-1=16。

所以,不可能。

2. 二叉树的根结点属于第0层还是属于第1层?第1层3. 已知一棵二叉树有20个结点,其中6个结点为叶子,则该树中度为2的结点数为 5 ?度为0的结点为6 ?由性质3:n0=n2+1,则n2=n0-1=6-1=5。

相关文档
最新文档