【初阶数据结构】树和二叉树的基本概念和结构(上)

简介: 【初阶数据结构】树和二叉树的基本概念和结构

1.树的概念

学二叉树之前得先学树,后面也有能用到树的知识,比如并查集就是树当中的森林

1-1树的概念

树是一种非线性的数据结构,它是由N(N>=0)个有限结点组成的层次关系的集合,说它是树主要是因为他很像一棵倒挂的树,也就是根在是上,枝叶在下。

5d00c1a8d64e46b8b834d103cb3918af.png A为根结点,根节点没有前驱结点

树是递归定义的,树中最基本的关系就是父子关系,A是B和C的父节点,同时B也是D的父节点。(任何一棵树都可以分为根和子树)

ef651bf386f242e88cc0c0a40c451c88.png

上面两个图都不是树,因为树内部不能出现环,出现环就是我们后面要讲的图

1-2.树中的亲缘关系名词

653f4efb05be41629ad5fbaf4103f430.png


结点的度:一个结点所含子树的个数,比如结点A的度为2

叶子结点或终端结点:度为0的结点,比如结点D,G和E

分支结点或非终端结点:度不为0的结点,比如结点A,B和C

父节点或双亲结点:若一个结点有子节点,那么这个结点就被称为父节点,比如A是B和C的父节点

子节点或孩子结点:同理,比如B和C是A的子节点

兄弟节点:具有相同父节点的结点,比如B和C是兄弟结点(亲兄弟)

堂兄弟结点:父节点都在同一层的结点,比如D和G,E

树的度:一棵树中,最大的结点的度被称为树的度,比如该树的结点是2

结点的层次:从根开始定义,如果规定根为第一层,以此类推(推荐)

备注:如果规定根为第0层,以此类推也行,但数组从0开始时因为偏移量,这里没必要

而且如果一个如果要表示空树,显然规定根为第一层,更能合乎情理表示空树

结点的祖先:从根到该节点的经过分支的所有结点,比如G的祖先是A和C

结点的子孙:以某一个结点为根的子树中的任意一个结点,比如C的子孙是G和E

森林:由m(m>0)棵互不相交的树的集合


2.树的存储方式

2-1兄弟孩子表示法

不那么合适的写法:

由于我们不知道树的结点的度为多少,所以在树的结点定义的时候直接定义有点麻烦

//一:结点的度不知道,我怎么设计呐?
struct TreeNode
{
  int data;
  struct TreeNode* childNode1;
  struct TreeNode* childNode2;
  struct TreeNode* childNode3;
  //...
};
//二:如果明确树的度
//静态顺序表:
#define N 5
struct TreeNode
{
  int data;
  struct TreeNode* childArr[N];
  int childSize;
};
//缺点:但是这是树的度,不是每一个结点的度,会造成数组空间浪费
//三:动态顺序表:
struct TreeNode
{
  int data;
  struct TreeNode** childArr;
  int childSize;
};

最合适的写法:

兄弟孩子表示法

e982d7869aac473a8d69898b76744894.png

typedef int DataType;
struct TreeNode
{
  struct TreeNode* firstchild1;//第一个孩子结点
  struct TreeNode* pNextBrother;//指向第一个兄弟结点
  DataType _data;
};


39a6a8790f3d41e8aabafa02dde9ffeb.png

Linux目录系统结构:(树)

ba1d1e6cc4e9a69519cf05048d3202fd.jpg


2-2双亲表示法

任意一个结点找祖先


6d53edce142c4b1da552f9cb79b676f8.png

e85897139f1349c38d7ceef9d22de988.png

3.满二叉树和完全二叉树

二叉树:度为2的树;二叉树的结点的度只能为0或者2

任何二叉树都是由以下结构复合而成的


e2da95da279f419098acd5c915e54cd8.png

特殊的二叉树:

  1. 满二叉树:每一层都是满的,
    如果有K层,第K层结点个数:2^(K-1)      ;    总结点个数:2^k-1
  2. 完全二叉树:如果有K层,则前K-1层必须是 满的,最后一层满或不满都可以
    K层,结点数量范围是【2^(K-1),2^K-1】

81b6e46f5a6b482197266c20a150baef.png

2173ca9959d84ec584a4d51e2bdaa59b.png

4.二叉树的性质


性质1:在二叉树的第i层上至多有2^(i-1)个结点(数学归纳法或者错位相减法证明)

性质2:深度为i的二叉树至多有2^i-1个结点 (数学归纳法或者错位相减法证明)

性质3:对于任意一棵二叉树,若叶子数为n0,度为2的结点有n2,则n0=n2+1(数学归纳法)

性质4:具有n个结点的完全二叉树必为LogN+1(数学推导证明如下)

f2bfe4498e164506b355388d37975820.png




目录
相关文章
|
2天前
|
Java C++
【C++数据结构——树】二叉树的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现二叉树的基本运算。​ 相关知识 创建二叉树 销毁二叉树 查找结点 求二叉树的高度 输出二叉树 //二叉树节点结构体定义 structTreeNode{ intval; TreeNode*left; TreeNode*right; TreeNode(intx):val(x),left(NULL),right(NULL){} }; 创建二叉树 //创建二叉树函数(简单示例,手动构建) TreeNode*create
27 12
|
2天前
|
C++
【C++数据结构——树】二叉树的性质(头歌实践教学平台习题)【合集】
本文档介绍了如何根据二叉树的括号表示串创建二叉树,并计算其结点个数、叶子结点个数、某结点的层次和二叉树的宽度。主要内容包括: 1. **定义二叉树节点结构体**:定义了包含节点值、左子节点指针和右子节点指针的结构体。 2. **实现构建二叉树的函数**:通过解析括号表示串,递归地构建二叉树的各个节点及其子树。 3. **使用示例**:展示了如何调用 `buildTree` 函数构建二叉树并进行简单验证。 4. **计算二叉树属性**: - 计算二叉树节点个数。 - 计算二叉树叶子节点个数。 - 计算某节点的层次。 - 计算二叉树的宽度。 最后,提供了测试说明及通关代
27 10
|
2天前
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
16 2
|
16天前
|
数据库
数据结构中二叉树,哈希表,顺序表,链表的比较补充
二叉搜索树,哈希表,顺序表,链表的特点的比较
数据结构中二叉树,哈希表,顺序表,链表的比较补充
|
2月前
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
261 9
|
2月前
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
42 1
|
2天前
|
存储 C语言 C++
【C++数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现顺序栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 1.初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储
112 75
|
2天前
|
存储 C++ 索引
【C++数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】
【数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】初始化队列、销毁队列、判断队列是否为空、进队列、出队列等。本关任务:编写一个程序实现环形队列的基本运算。(6)出队列序列:yzopq2*(5)依次进队列元素:opq2*(6)出队列序列:bcdef。(2)依次进队列元素:abc。(5)依次进队列元素:def。(2)依次进队列元素:xyz。开始你的任务吧,祝你成功!(4)出队一个元素a。(4)出队一个元素x。
24 13
【C++数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】
|
2天前
|
存储 C语言 C++
【C++数据结构——栈与队列】链栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现链栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储整数,最大
25 9
|
2天前
|
C++
【C++数据结构——栈和队列】括号配对(头歌实践教学平台习题)【合集】
【数据结构——栈和队列】括号配对(头歌实践教学平台习题)【合集】(1)遇到左括号:进栈Push()(2)遇到右括号:若栈顶元素为左括号,则出栈Pop();否则返回false。(3)当遍历表达式结束,且栈为空时,则返回true,否则返回false。本关任务:编写一个程序利用栈判断左、右圆括号是否配对。为了完成本关任务,你需要掌握:栈对括号的处理。(1)遇到左括号:进栈Push()开始你的任务吧,祝你成功!测试输入:(()))
21 7