- 0
- 0
- 约2.26万字
- 约 28页
- 2022-06-15 发布于新疆
- 举报
`
计算机2020-78班数据结构
2020-5-7
树 --树的定义和术语
¨两种树:自由树与有根有序树。
t自由树:一棵自由树 Tf 可定义为一个二元组Tf = (V, E),其中V = {v1, ..., vn} 是由 n (n>0) 个元素组成的有限非空集合,称为顶点(vertex)集合。E = {(vi, vj) | vi, vj V, 1≤i, j≤n} 是n-1个序对的集合,称为边集合,E 中的元素 (vi, vj)称为边(edge)或分支。
¨有根树:一棵有根树 T,简称为树,它是n (n≥0) 个结点的有限集合。当n = 0时,T 称为空树;否则,T 是非空树,记作
其中,r 是一个特定的称为根(root)的结点,它没有直接前驱;根以外的其他结点划分为 m (m ≥0) 个互不相交的有限集合T1, T2, …, Tm,每个集合又是一棵树,并且称之为根的子树。
t相关术语
t子女:若结点的子树非空,结点子树的根即为该结点的子女。
t双亲:若结点有子女,该结点是子女双亲。
t兄弟:同一结点的子女互称为兄弟。
t度:结点的子女个数即为该结点的度;树中各个结点的度的最大值称为树的度。
t分支结点:度不为0的结点即为分支结点,亦称为非终端结点。
t叶结点:度为0的结点即为叶结点,亦称为终端结点。
t祖先:某结点到根结点的路径上的各个结点都是该结点的祖先。
t子孙:某结点的所有下属结点,都是该结点的子孙。
t结点的层次:规定根结点在第一层,其子女结点的层次等于它的层次加一。以此类推。
t深度:结点的深度即为结点的层次;离根最远结点的层次即为树的深度。
t高度:规定叶结点的高度为1,其双亲结点的高度等于它的高度加一。
t树的高度:等于根结点的高度,即根结点所有子女高度的最大值加一。
t有序树:树中结点的各棵子树 T0, T1, …是有次序的,即为有序树。
t无序树:树中结点的各棵子树之间的次序是不重要的,可以互相交换位置。
t森林:森林是m(m≥0)棵树的集合。
树 --树的抽象数据类型
template class T
class Tree {
//在类界面中的 position 是树中结点的地址。在顺序
//存储方式下是下标型, 在链表存储方式下是指针型
public:
Tree ();
~Tree ();
position Root();
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(const position p, const T value);
//在结点 p 下插入值为 value 的新子女, 若插
//入失败, 函数返回false, 否则返回true
bool DeleteChild (position p, int i);
//删除结点 p 的第 i 个子女及其全部子孙结
//点, 若删除失败, 则返回false, 否则返回true
void DeleteSubTree (position t);
//删除以 t 为根结点的子树
bool IsEmpty ();
//判树空否, 若空则返回true, 否则返回false
void Traversal (void (*visit)(position p));
//遍历以 p 为根的子树
};
二叉树 --二叉树的定义
t一棵二叉树是结点的一个有限集合,该集合或者为空,或者是由一个根结点加上两棵分别称为左子树和右子树的、互不相交的二叉树组成。
二叉树 --二叉树的性质
¨性质1 若二叉树结点的层次从 1 开始, 则在二叉树的第 i (i≥1)层最多有 2i-1 个结点。
[证明用数学归纳法]
t性质2 深度为 k (k≥0) 的二叉树最少有 k 个结点,最多有 2k-1个结点。
t证明:因为每一层最少要有1个结点,因此,最少结点数为 k。最多结点个数借助性质1用求等比级数前k项和的公式20 +21 +22 + …+2k-1 = 2k-1
t性质3 对任何一棵
您可能关注的文档
- 操作系统试验.docx
- 计算机20级7班+张晴+5011220733+实验二.docx
- 实验二windows进程的创建与销毁.docx
- 数据结构课程设计题目要求(1).doc
- 大学英语期末考试考生注意事项.docx
- 单片机不看书版(1).docx
- 实验9 索引实验.doc
- 计算方法模拟试题(1-15)解答.doc
- 实验10 触发器的创建和使用.doc
- 数值计算方法选择题.doc
- 河北盐山中学等校2025-2026学年上学期高三一模化学试卷(含解析).docx
- 河北正定中学2025-2026学年高一上学期期末考试物理试卷(含解析).docx
- 河北张家口市怀安县2025-2026学年第一学期期末教学综合评价八年级地理试卷(含解析).docx
- 河南安阳市殷都区2025-2026学年第一学期期末教学质量检测七年级地理试卷(含解析).docx
- 河南安阳市滑县2025一2026学年第一学期期末学业质量监测八年级地理试题(含解析).docx
- 河南安阳市林州市2025-2026学年上学期期末考试高一政治试题(含解析).docx
- 河南焦作市武陟县第一中学2025-2026学年高一上学期1月月考语文试卷(含解析).docx
- 河南济源市2025-2026学年上学期期末学业质量调研七年级历史试卷(含解析).docx
- PICC导管并发症的紧急处理与护理.pptx
- 河南鹤壁市2025-2026学年高二上学期期末考试生物试题(含解析).docx
原创力文档

文档评论(0)