- 1、本文档共175页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
线性结构与非线性结构
数据结构课程中数据的逻辑结构分为线性结构和非线性结构。
对于数据结构课程而言,简单地说,线性结构是n个数据元素的有序(次序)集合。
特征
1.集合中必存在唯一的一个第一个元素;
2.集合中必存在唯一的一个最后的元素;
3.除最后元素之外,其它数据元素均有唯一的后继;
4.除第一元素之外,其它数据元素均有唯一的前驱。
相对应于线性结构,非线性结构的逻辑特征是一个结点元素可能对应多个直接前驱和多个后继。
2
第五章 树与二叉树
3
第五章 树与二叉树
树和森林的概念
二叉树
二叉树遍历
二叉树的计数
线索化二叉树
树与森林
堆
Huffman树
4
树和森林的概念
两种树:自由树与有根树。
自由树:
一棵自由树 Tf 可定义为一个二元组
Tf = (V, E)
其中V = {v1, ..., vn} 是由 n (n>0) 个元素组成的有限非空集合,称为顶点集合。E = {(vi, vj) | vi, vj ?V, 1≤i, j≤n} 是n-1个序对的集合,称为边集合,E 中的元素 (vi, vj)称为边或分支。
在自由树中选定一顶点做根,则成为一棵通常的树
连通的,有n-1条边,且没有简单回路
5
自由树
有根树: 一棵有根树 T,简称为树,它是n (n≥0) 个结点的有限集合。当n = 0时,T 称为空树;否则,T 是非空树,记作
6
r 是一个特定的称为根(root)的结点,它只有直接后继,但没有直接前驱;
根以外的其他结点划分为 m (m ? 0) 个互不相交的有限集合T1, T2, …, Tm,每个集合又是一棵树,并且称之为根的子树。
每棵子树的根结点有且仅有一个直接前驱,但可以有0个或多个直接后继。
7
层次关系:
家谱中的双亲子女关系
组织中的上下级关系
计算机文件系统中的目录与子目录关系
表达式中的括号嵌套关系,等等
对这些关系及相关对象进行抽象,就形成了计算机科学中最重要的数据结构之一 ?? 树。
8
树的基本术语
子女:若结点的子树非空,结点子树的根即为该结点的子女。
双亲:若结点有子女,该结点是子女双亲。
9
兄弟:同一结点的子女互称为兄弟。
度:结点的子女个数即为该结点的度;树中各个结点的度的最大值称为树的度。
分支结点:度不为0的结点即为分支结点,亦称为非终端结点。
叶结点:度为0的结点即为叶结点,亦称为终端结点。
祖先:某结点到根结点的路径上的各个结点都是该结点的祖先。
子孙:某结点的所有下属结点,都是该结点的子孙。
10
结点的层次:规定根结点在第一层,其子女结点的层次等于它的层次加一。以下类推。
深度:结点的深度即为结点的层次;离根最远结点的层次即为树的深度。
11
结点高度:规定叶结点的高度为1,其双亲结点的高度等于它的高度加一。
树的高度:等于根结点的高度。
有序树:树中结点的各棵子树 T0, T1, …是从左到右有次序的(即不能互换) ,即为有序树(OrderedTree) 。
无序树:树中结点的各棵子树之间的次序是不重要的,可以互相交换位置(UnorderedTree)。
注意:若不特别指明,一般讨论的树都是有序树。
森林:森林是m(m≥0)棵树的集合。
12
树的抽象数据类型
template class T
class Tree {
//对象: 树是由n (≥0) 个结点组成的有限集合。在
//类界面中的 position 是树中结点的地址。在顺序
//存储方式下是下标型, 在链表存储方式下是指针
//型。T 是树结点中存放数据的类型, 要求所有结
//点的数据类型都是一致的。
public:
Tree ();
~Tree ();
13
BuildRoot (const T value);
//建立树的根结点
position FirstChild(position p);
//返回 p 第一个子女地址, 无子女返回 0
position NextSibling(position p);
//返回 p 下一兄弟地址, 若无下一兄弟返回 0
position Parent(position p);
//返回 p 双亲结点地址, 若 p 为根返回 0
T getData(position p);
//返回结点 p 中存放的值
bool InsertChild(position p, T value);
//在结点 p 下插入值为 value 的新子女, 若插
//入失败, 函数返回false, 否则返回true
14
文档评论(0)