数据结构期末考点总结

合集下载

数据结构总结期末总结报告

数据结构总结期末总结报告

数据结构总结期末总结报告数据结构是计算机科学中一个非常重要的基础课程,它研究的是计算机中数据的组织方式和存储结构,为算法和程序的设计提供了基础。

本报告将对我在本学期学习数据结构课程的收获进行总结。

一、知识框架梳理本学期学习的数据结构课程主要包括线性结构、树形结构、图形结构等内容。

在学习过程中,我首先对每一种数据结构的基本原理进行了学习和理解,通过课堂讲解、教材阅读以及与同学交流,我逐渐形成了对数据结构的整体框架。

1. 线性结构(数组、链表、栈、队列)线性结构是最简单的数据结构之一,它的特点是数据元素之间只存在一对一的关系。

在本学期的学习中,我了解了数组、链表、栈和队列等线性结构的基本原理和实现方式。

数组是一种具有固定大小的数据结构,它的特点是内存连续、随机访问,但插入和删除操作比较低效。

链表是一种动态的数据结构,它的特点是内存不连续、插入和删除操作高效,但随机访问效率较低。

栈和队列都是基于线性结构的特殊形式,栈是后进先出(LIFO)的结构,而队列是先进先出(FIFO)的结构。

通过对这些线性结构的学习,我进一步提高了对数据的组织和操作的理解。

2. 树形结构(二叉树、堆、哈希表)树形结构是线性结构的扩展,它的特点是数据元素之间存在一对多的关系。

在本学期的学习中,我了解了二叉树、堆和哈希表等树形结构的基本原理和实现方式。

二叉树是一种每个节点最多有两个子节点的树形结构,它的特点是插入、删除操作高效,但查找操作效率较低。

堆是一种特殊的二叉树结构,它的特点是每个节点的值都大于等于(或小于等于)其子节点的值。

堆主要用于实现优先队列,通过堆的调整(上滤和下滤)可以实现高效的插入和删除操作。

哈希表是一种通过哈希函数将数据映射到固定大小的数组中的数据结构,它的特点是查找操作效率很高,但插入和删除操作的效率较低。

通过对这些树形结构的学习,我进一步提高了对数据的组织和操作的理解,并学到了一些高效的算法和技巧。

3. 图形结构(图、邻接表、邻接矩阵)图形结构是一种多对多的数据结构,它的特点是数据元素之间存在多对多的关系。

数据结构期末复习汇总

数据结构期末复习汇总

数据结构期末复习汇总数据结构是计算机科学中十分重要的概念之一,它是指数据对象以及数据对象之间的关系、操作和操作规则的集合。

在计算机科学的学习中,掌握数据结构是至关重要的一步。

为了帮助大家复习期末考试,以下是一些数据结构的重要知识点的总结。

一、线性表线性表是最简单的一种数据结构,它是一种有序的数据元素集合。

线性表的特点是元素之间的关系是一对一的关系,每个元素都与它的前驱和后继相连接。

1.数组:数组是最常见的线性表结构,它由相同类型的数据元素组成,这些元素通过索引来访问。

2.链表:链表是另一种常见的线性表结构,它由节点组成,每个节点包含了数据以及一个指向下一个节点的指针。

二、栈和队列栈和队列是常用的线性结构,它们在操作上有一些限制。

1.栈:栈是一种具有后进先出(LIFO)特性的线性表。

栈中的元素只能在栈顶进行插入和删除操作。

2.队列:队列是一种具有先进先出(FIFO)特性的线性表。

队列中的元素只能在队尾进行插入操作,在队头进行删除操作。

三、树和二叉树树是一种非线性的数据结构,它由节点和边组成。

树的一个节点可以有多个子节点,但是每个节点只能有一个父节点。

1.二叉树:二叉树是一种特殊的树结构,每个节点最多只能有两个子节点。

2.二叉树:二叉树是一种特殊的二叉树,它满足左子树的所有节点的值都小于根节点的值,右子树的所有节点的值都大于根节点的值。

四、图图是一种非常重要的非线性结构,它由节点和边组成。

图的节点之间可以有多种不同的关系。

1.有向图:有向图是一种图结构,图的边有方向,从一个节点到另一个节点。

2.无向图:无向图是一种图结构,图的边没有方向。

五、排序和算法排序算法是对一组数据进行排序的算法,算法是找到目标元素在一组数据中的位置的算法。

1.冒泡排序:冒泡排序是一种交换排序算法,其核心思想是比较相邻的元素并进行交换,将最大(或最小)元素逐渐“冒泡”到数组的末尾。

2.快速排序:快速排序是一种分治排序算法,其核心思想是通过选择一个基准元素,将数组划分为两个子数组,其中一个子数组的所有元素都小于基准元素,另一个子数组的所有元素都大于基准元素,然后对两个子数组进行递归排序。

数据结构期末复习重点知识点总结

数据结构期末复习重点知识点总结

数据结构期末复习重点知识点总结一、数据结构概述数据结构是计算机科学中一门关于数据组织、存储和管理的学科。

它涉及到各种数据类型和它们之间的关系,以及对这些数据类型进行有效操作和处理的算法。

二、基本数据结构1. 数组- 数组是一种线性数据结构,用于存储相同类型的数据元素。

- 数组的特点是随机访问和连续存储。

- 数组的插入和删除操作需要移动其他元素,时间复杂度为O(n)。

2. 链表- 链表是一种线性数据结构,通过节点之间的指针链接来组织数据。

- 链表的特点是插入和删除操作简单,时间复杂度为O(1)。

- 链表分为单链表、双向链表和循环链表等不同类型。

3. 栈- 栈是一种具有后进先出(LIFO)特性的数据结构。

- 栈的操作主要包括压栈(Push)和弹栈(Pop)两个操作。

- 栈常用于表达式求值、递归算法的实现等场景。

4. 队列- 队列是一种具有先进先出(FIFO)特性的数据结构。

- 队列的操作主要包括入队(Enqueue)和出队(Dequeue)两个操作。

- 队列常用于实现缓冲区、消息队列等场景。

5. 树- 树是一种非线性的数据结构,由节点和边组成。

- 树的节点具有层级关系,由根节点、子节点和叶节点等组成。

- 常见的树结构有二叉树、红黑树、B树等。

6. 图- 图是一种非线性的数据结构,由节点和边组成。

- 图的节点之间可以有多对多的关系。

- 图的遍历方式有深度优先搜索(DFS)和广度优先搜索(BFS)。

三、常见的数据结构算法1. 排序算法- 冒泡排序、插入排序、选择排序等简单但效率较低的排序算法。

- 快速排序、归并排序、堆排序等高效的排序算法。

- 基数排序、桶排序等适用于特定场景的排序算法。

2. 查找算法- 顺序查找、二分查找等常用的查找算法。

- 树结构相关的查找算法,如二叉搜索树、红黑树等。

- 哈希查找、索引查找等高效的查找算法。

3. 图算法- Dijkstra算法、Bellman-Ford算法等最短路径算法。

数据结构笔记期末总结

数据结构笔记期末总结

数据结构笔记期末总结一、概述在本学期的学习中,我们主要学习了数据结构及其相关的算法。

数据结构是计算机科学的基础,是任何程序设计的基础。

它研究如何组织和存储数据,以及如何高效地访问和操作数据。

在学习过程中,我们通过理论讲解、实验操作、编程实践等方式加深了对数据结构的理解和应用能力的提升。

本文将对本学期所学的内容进行总结,以期对数据结构的学习有一个全面的回顾与总结。

二、线性结构1. 数组数组是一种线性结构,它将相同数据类型的元素按照一定的顺序排列,并按照一定的规则访问这些元素。

在数组中,每个元素都有一个索引,通过索引可以快速地访问数组中的元素。

数组的优点是存储效率高,支持随机访问;缺点是插入和删除操作比较低效。

2. 链表链表是由一系列节点组成的线性结构,每个节点包含一个数据元素和一个指向下一个节点的指针。

链表分为单向链表和双向链表,单向链表的每个节点只有一个指针,指向下一个节点;双向链表的每个节点有两个指针,一个指向前一个节点,一个指向后一个节点。

链表的优点是插入和删除操作高效,支持动态扩容;缺点是访问元素的效率较低。

3. 栈栈是一种具有特定操作规则的线性结构,它的特点是先进后出。

栈有两个基本操作:入栈和出栈。

入栈操作将一个元素放入栈顶,出栈操作将栈顶元素移除。

栈的应用场景很多,比如函数调用栈、表达式求值等。

4. 队列队列是一种具有特定操作规则的线性结构,它的特点是先进先出。

队列有两个基本操作:入队和出队。

入队操作将一个元素放入队尾,出队操作将队头元素移除。

队列的应用场景很多,比如任务调度、消息传递等。

三、非线性结构1. 树树是一种非线性结构,它由节点组成,节点之间存在一对多的层次关系。

树的基本概念包括根节点、叶子节点、父节点、子节点等。

树的应用场景很多,比如文件系统、数据库索引等。

2. 二叉树二叉树是一种特殊的树,它的每个节点最多有两个子节点,分别称为左子节点和右子节点。

二叉树的遍历方式有前序遍历、中序遍历和后序遍历。

数据结构期末复习总结

数据结构期末复习总结

第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>有时候关系图不唯一(一般是无向图)●数据结构在计算机内存中的存储包括数据元素的存储和元素之间的关系的表示。

数据结构期末概念总结

数据结构期末概念总结

数据结构期末概念总结第一部分:基本概念和算法复杂度分析1. 数据结构的定义和分类2. 算法的定义和特性3. 算法复杂度分析的方法和技巧4. 时间复杂度和空间复杂度的计算和比较5. 最坏情况、平均情况和最好情况的复杂度分析6. Big-O符号和渐进记号法的使用和解读第二部分:线性数据结构1. 数组和链表的定义、特性和比较2. 栈和队列的定义、特性和应用3. 双向链表和循环链表的定义、特性和应用4. 线性数据结构的遍历和操作算法5. 线性数据结构的实现和优化技巧第三部分:树和二叉树1. 树的定义、特性和应用2. 二叉树的定义、特性和分类3. 二叉树的遍历算法(前序、中序、后序、层序)4. 二叉搜索树的定义、特性和操作算法5. 平衡二叉树和AVL树的定义、特性和操作算法6. 堆和二叉堆的定义、特性和应用第四部分:图1. 图的定义、特性和分类2. 图的表示方法(邻接矩阵、邻接表、哈希表)3. 图的遍历算法(深度优先搜索、广度优先搜索)4. 最短路径算法(Dijkstra算法、Floyd-Warshall算法)5. 最小生成树算法(Prim算法、Kruskal算法)第五部分:高级数据结构1. 哈希表的定义、特性和应用2. 字典树的定义、特性和应用3. 线段树的定义、特性和应用4. 并查集的定义、特性和应用第六部分:高级算法思想1. 分治算法和递归思想2. 动态规划算法和状态转移方程3. 贪心算法和贪心选择策略4. 回溯算法和剪枝技巧在本篇文章中,我从基本概念和算法复杂度分析开始,系统地总结了数据结构课程的内容。

通过对线性数据结构(数组、链表、栈、队列)、树和二叉树、图、高级数据结构(哈希表、字典树、线段树、并查集)以及高级算法思想的介绍,读者们可以对数据结构的主要概念有一个全面的了解。

当然,数据结构不仅仅是掌握概念,更重要的是能够灵活运用这些概念解决实际问题。

因此,读者们在学习数据结构的过程中,一定要多做练习和实践,深入理解每种数据结构的应用场景和实现细节。

期末数据结构复习总结

期末数据结构复习总结

数据结构第一章1、数据是描述客观事物的数和字符的集合2、数据项:是具有独立含义的数据最小单位,也称为字段或域3、数据对象:指性质相同的数据元数的集合,是数据的一个子集4、数据结构:指所有数据元素以及数据元素之间的关系5、数据的逻辑结构:由数据元素之间的逻辑关系构成6、数据的存储结构:数据元素及其关系在计算机存储器中的存储表示,称为物理结构逻辑结构的表达方式:1、图表表示:采用表格或图形直接描述数据的逻辑关系。

2、二元组表示:通用的数据逻辑结构表示方式:R={r},r={<010,021>,<021,027>,<027,029>}逻辑结构的类型:1、集合:指数据元素之间除了“同属于一个集合”的关系以外别无其他关系。

2、线性结构:一对一关系,只有一个前驱和一个后继元素。

3、树形结构:多对多关系,除了开始元素以外,都只有一个前驱和多个后继元素。

什么是算法:是问题求解步骤的描述,是指令的有限序列。

1、有穷性:执行有穷步后结束2、确定性:不能有二义性3、可行性:算法可以通过有限次的操作完成其功能,能够被重复地执行4、有输入:一个算法有0个或多个输入5、有输出:一个算法有一个或多个输出算法设计的目标:正确性(算法能正确执行)、可使用性(方便地使用)、可读性(算法易于理解)、健壮性(有好的容错性,不会异常中断或死机)、高效率与低存储量需求(算法的执行时间和存储空间)算法时间性分析方法:事后统计法(缺点:必须执行、存在很多因素掩盖算法本质)、事前估算法(仅考虑算法本身的效率高低、只依赖于问题的规模)第二章线性表:具有相同特性的数据元素的一个有限序列有序表:指线性表中的所有元素按递增或剃减方式有序排列顺序表:线性表的顺序存储结构简称为顺序表(下标从0开始),从逻辑上相邻的元素对应的物理存储位置也相邻,当进行插入或删除的操作时要平均移动半个表的元素,相当费时。

链表:线性表的链式存储结构称为链表,拥有唯一的标识头指针(head pointer),相应的指向开始结点(first pointer),指向尾结点的称为尾指针(tail pointer)。

(完整word版)大学数据结构期末知识点重点总结(考试专用)

(完整word版)大学数据结构期末知识点重点总结(考试专用)

第一章概论1。

数据结构描述的是按照一定逻辑关系组织起来的待处理数据元素的表示及相关操作,涉及数据的逻辑结构、存储结构和运算2。

数据的逻辑结构是从具体问题抽象出来的数学模型,反映了事物的组成结构及事物之间的逻辑关系可以用一组数据(结点集合K)以及这些数据之间的一组二元关系(关系集合R)来表示:(K, R)结点集K是由有限个结点组成的集合,每一个结点代表一个数据或一组有明确结构的数据关系集R是定义在集合K上的一组关系,其中每个关系r(r∈R)都是K×K上的二元关系3.数据类型a。

基本数据类型整数类型(integer)、实数类型(real)、布尔类型(boolean)、字符类型(char)、指针类型(pointer)b。

复合数据类型复合类型是由基本数据类型组合而成的数据类型;复合数据类型本身,又可参与定义结构更为复杂的结点类型4.数据结构的分类:线性结构(一对一)、树型结构(一对多)、图结构(多对多)5。

四种基本存储映射方法:顺序、链接、索引、散列6。

算法的特性:通用性、有效性、确定性、有穷性7.算法分析:目的是从解决同一个问题的不同算法中选择比较适合的一种,或者对原始算法进行改造、加工、使其优化8.渐进算法分析a.大Ο分析法:上限,表明最坏情况b.Ω分析法:下限,表明最好情况c.Θ分析法:当上限和下限相同时,表明平均情况第二章线性表1.线性结构的基本特征a.集合中必存在唯一的一个“第一元素”b。

集合中必存在唯一的一个“最后元素"c.除最后元素之外,均有唯一的后继d。

除第一元素之外,均有唯一的前驱2.线性结构的基本特点:均匀性、有序性3。

顺序表a.主要特性:元素的类型相同;元素顺序地存储在连续存储空间中,每一个元素唯一的索引值;使用常数作为向量长度b。

线性表中任意元素的存储位置:Loc(ki)= Loc(k0)+ i * L(设每个元素需占用L个存储单元)c. 线性表的优缺点:优点:逻辑结构与存储结构一致;属于随机存取方式,即查找每个元素所花时间基本一样缺点:空间难以扩充d.检索:ASL=【Ο(1)】e。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
} 取对头 Status GetHead(sqqueue &Q,Qelemtype &e)
{ if (Q.front == Q.rear ) return ERROR; return Q.base[Q.front];
}
第四章
重点:串的比较、连接,了解串的插入,删除 定义 typedef struct { char *ch;
}
第五章 数组和广义表
重点:特殊矩阵,稀疏矩阵(明白思路)
对称矩阵 aij=aji 0≤i,j ≤n-1
SA[k]= aij
k=i(i+1)/2+j(i>=j)或 k=j(j+1)/2+i(i< j)
稀疏矩阵 一般采用三元组存储一个非零元素。
如:三元组
(1,5,a) (2,2,b) (3,4,c) (4,7,d)
} TSmatrix
第六章 树与二叉树
重点:1、二叉树的遍历和性质,
2、树的存储结构及遍历
3、哈夫曼树
基本概念
结点的度 : 结点拥有子树的数目
i
叶结点 : 结点的度为零的结点
分枝结点 : 结点的度非零的结点
树的度 : 树中各结点度的最大值
孩子
: j,k,l 称为 i 的孩子
j
k
l
双亲
: i 称为 j,k,l 的双亲
typedef struct Dublnode{ Elemtype data; struct Dublnode *prior ; struct Dublnode *next ;
}Dublnode,*Dublinklist ; 了解:有序表的合并
void Mergelist_L(Linklist &La, Linklist &Lb, Linklist &Lc) { pa=La->next; pb=Lb->next; Lc=pc=La; while (pa&&pb) { if ( pa->data<=pb->data) { pc->next=pa;pc=pa;pa=pa->next;} else { pc->next=pb;pc=pb;pb=pb->next;} } pc->next =pa?pa:pb; free(Lb); }
} 栈的插入 Status Push(Sqstack &s,Selemtype e)
{ if (s.top-s.base>=s.stacksize) { s.base=追加分配空间; s.stacksize+=Stackincrement; }
*s.top++=e; return Ok } 栈的删除栈顶 Status Pop(Sqstack &s,Selemtype &e) { if (s.top==s.base) return ERROR; e=*--s.top return Ok } 队列的顺序存储表示与实现 typedef struct{ Qelemtype *base; int front; 指向第一个元素(有数) int rear; 指向最后一个元素的下一位(为空) }Sqqueue; 队空条件: Q.front = Q.rear 队满条件: (Q.rear+1) % Maxsize= Q.front 队列长度:(Q.rear-Q.front+Maxsise)%Maxsize 队的插入: Status Enqueue(sqqueue &Q,Qelemtype e) { if ((Q.rear+1)%Maxsize==Q.front)
}
}
先序
Void preorder(bt)
{ if (bt)
{visit(bt->data);
preorder(bt->lchild);
} 线性表定位删除
Status Listdelete_Sq(Sqlist &L,int i, Elemtype &e) {
if (i<1‖i >L.length) return ERROR; e= L.elem[i-1]); for (j=i;j<L.length;++j)
L.elem[j-1]=L.elem[j]); --L.length; return OK; } 单链表定义:
int length; } Hstring ; 比较 status strcompare(S,T) { for (i=0;i<S.length &&i<T.length; ++i)
if ( S.ch[i]!=T.ch[i] ) return S.ch[i]-T.ch[i]; return S.length-T.length; } 连接 Status concat(&t,s1,s2)
return ERROR; Q.base[Q.rear]=e; Q.rear=(Q.rear+1)%Maxsize; return OK; } 队的删除 Status Dequeue(sqqueue &Q,Qelemtype &e)
{ if (Q.front == Q.rear ) return ERROR; e=Q.base[Q.front]; Q.front=(Q.front+1)%Maxsize; return OK;
第二章 线性表
重点: 1、链式和线性表两种方式的插入与删除 2、单双链表的定义 线性表的定义 #define List-Init-Size 100 #define Listincrement 10 typedef struct {
Elemtype *elem; int length; int listsize; } Sqlist; 线性表定位插入 Status Listinsert_Sq(Sqlist &L,int i, Elemtype e)
typedef struct Lnode { Elemtype data; struct Lnode *next;
} Lnode, *Linklist; 链式定位插入
Status Listinsert_L(Linklist &L,int i,Elemtype e) { p=L; j=0; while (p&&j<i-1) {p=p->next;++j } if ( !p ‖j>i-1) return ERROR; new(s); s->data=e; s->next=p->next; p->next=s; return OK; }
性质 2: 深度为 k 的二叉树,至多有 2k -1 个结点。(等比求和)
性质 3: 对任意二叉树 BT ,若叶结点数为 n0 ,度为 2 的结点数为 n2,则 n0 = n2 +1
性质 4:具有 n 个结点的完全二叉树深度为 [ log2n ]+1 (取整)
性质 5:对结点数为 n 的完全二叉树,第 i 个结点有如下特征:
兄弟
: j,k,l 互为兄弟
祖先
: 树的根结点到某结点 j 路径上的所有结点,为结点 j 的祖先
子孙
: 结点 i 下的所有结点,称为结点 i 的子孙
结点层次 : 从根结点到某结点 j 路径上结点的数目
树的深度 : 树中结点的最大层次
有序树 : 若树中结点的各子树从左到右是有次序的,称该树为有序树,否则为无序树
第一章 绪论
数据——所有输入计算机中并被计算机处理的符号。 数据元素——数据的基本单位,通常作为一个整体。 数据对象——性质相同的数据元素的集合。 数据结构——数据元素以及之间存在的关系。
1 、线性结构;2、集合结构 3、树形结构; 4、图结构 数据结构的形式定义:Data--Structure=(D,S) D——数据元素集合 S——关系集合 数据的逻辑结构——用形式化方式描述数据元素间的关系。 数据的物理结构——数据在计算机中的具体表示。 数据类型——一种数据结构和定义在其上的一组操作。可以形式化定义为: Data--Type=(D,S,P) 算法的定义 是对特定问题求解步骤的一种描述, 是指令的有限序列。 算法的特性 有穷性——算法必须在执行有穷步之后结束,而且每一步都可在有穷时间内完成。 确定性——每条指令无二义性。 可行性——算法中描述的每一操作,都可以通过已经实现的基本运算来实现。 输入——算法有零至多个输入。 输出——算法有一个至多个输出。 时间复杂度的等级 O(1) O(log n) O(n) O(n×log n) O (n2) O (nK) O(Xn )
0000a00

0b0000
0
000c000 m
000000 ×
d
n
三元组定义
#define Maxsize=1000
typedef struct
{ int
i , j;
elemtype e;
} triple
typedef struct
{ triple data[Maxsize+1]
int
m , n , num;
森林
: 由 m 棵互不相交的树构成 F=(T1,T2,.......Tm)
二叉树的性质
定义: 深度为 k 且有 2k -1 个结点的二叉树称为满二叉树
定义: 深度为 k 且有 n 个结点的二叉树,当且仅当 n 个结点都满足满二叉树的位置编号
的升序排列结构时,称为完全二叉树
性质 1: 在二叉树的 i 层上至多有 2i -1 个结点。(归纳法证明)

{ if (t.ch) free(t.ch); if ( ! (T.ch=(char*) malloc((s1.length+s2.lengrh)*sizeof(char)))) exit(overflow); t.ch[0..s1.length-1]=s1.ch[0..s1.length-1]; t.length=s1.length+s2.length; t.ch[s1.length..t.length-1]=s2.ch[0..s2.length-1]; return OK;
相关文档
最新文档