数据结构基础详解(C语言): 树与二叉树的基本类型与存储结构详解

简介: 本文介绍了树和二叉树的基本概念及性质。树是由节点组成的层次结构,其中节点的度为其分支数量,树的度为树中最大节点度数。二叉树是一种特殊的树,其节点最多有两个子节点,具有多种性质,如叶子节点数与度为2的节点数之间的关系。此外,还介绍了二叉树的不同形态,包括满二叉树、完全二叉树、二叉排序树和平衡二叉树,并探讨了二叉树的顺序存储和链式存储结构。

@[toc]

1.树

树的基本概念

image.png

结点的度:指该结点的分支个数,如结点A的度为2
树的度:指树中最大的结点度数,如该树的度为3
祖先和子孙:对于某结点来说,从根到该结点所经的所有结点称为该结点的祖先。反之,以某结点为根的所有子树上的结点称为该结点的子孙。如路径ABEH,ABE是H的祖先,BEH是A的子孙。

2.二叉树

2.1 二叉树的基本概念

复习概念:m叉树 度≤m的树
等比数列求和公式:S~n~=a~1~(1-q^n^)/(1-q)
树节点的度数即为该节点孩子的个数。

二叉树是度小于等于2的有序树。(左右子树顺序不能颠倒)

性质:

  • 对任意一棵二叉树,如果用n~0~表示叶子结点的数量,用n~2~表示度为2的结点的数量,则有n~0~=n~2~+1
  • 非空二叉树第k层最多有2^k-1^个结点
  • 深度为h的二叉树最多有2^h^-1个结点

推导
假设树中结点总数为n,则
n=n~0~+n~1~+n~2~ (二叉树结点总数=度为0的结点数+度为1的结点数+度为2的结点数)
n=n~1~+2n~2~+1(树的结点总数=总度数+1)总度数=n*度为n结点数之和(二叉树是0-2)
上面两个方程作差即得到n~0~=n~2~+1

二叉树的五种状态:
image.png

2.2 满二叉树

顾名思义:每一个非叶子结点的结点的度都是2
一棵高度为h,且含有2^h^-1个结点的树

推导:2^0^+2^1^+.....2^n^=1(1-2^n^)(1-2)=2^n^-1

特点:
:one:只有最后一层有叶子结点
:two:不存在度为1度结点
:three:按层序从1开始编号,结点i的左孩子为2i,右孩子为2i+1,结点i的父结点为⌊i/2⌋

2.3 完全二叉树

完全二叉树是指从左到右从上到下依次补满全部结点的树,停止于任意位置,序号一一对应。
结论:满二叉树是一种特殊的完全二叉树

image.png

特点:

  • 若完全二叉树的深度为h,则它的前h-1层全是满的
  • 只有最后两层可能有叶子结点,且最底层的叶子结点依次排列在最左边。
  • 最多只有一个度为1的点
  • 有n个结点的完全二叉树的深度⌊ log~2~n⌋+1⌈ log~2~n+1⌉

    推导&解释
    使用这两个公式都可以通过结点数计算出完全二叉树的高度
    推导过程:⌈log~2~(n+1)⌉
    上取整通过≤最大值证明出
    结点n最大为2^h^-1,必然也肯定大于下一高度的最大值2^h-1^-1
    2^h-1^-1<n≤2^h^-1
    中间值+1后,取log2,并且上取整,满足该条件
    ⌈log~2~(n+1)⌉

推导过程:⌊log~2~n⌋+1
上取整通过≥最小值证明出
结点n最少的可能就是上一层满了,下一层一个,即2^h-1^-1+1=2^h-1^,肯定小于结点最大值+1
2^h-1^≤n<2^h^
取log2,下取整,再+1,即证毕,⌊log~2~n⌋+1

  • 对于完全二叉树,由结点数就可以推出各个度的结点数的个数。(n~0~,n~1~,n~2~)

    推导:记忆是困难的,通过推导辅助记忆
    (1) 完全二叉树最多只有一个度为1度结点(完全二叉树的性质)推出 完全二叉树度为1度结点要么是0,要么是1.
    (2)n~0~=n~2~+1推出n~0~+n~2~=n~2~+1+n~2~=2n~2~+1推出一定是奇数
    最终推,若完全二叉树有2k个结点(偶数)个结点,即n~0~+n~1~+n~2~=偶数,n~0~+n~2~=奇数,所以n~1~=1,n~0~=k,n~2~=k-1.若是奇数个结点(2k-1)个结点,n~1~=0,n~0~和n~2~同偶数,写法是不变的

2.4 二叉排序树

左子树结点值<根节点值<右子树结点值

image.png

2.5 平衡二叉树

平衡二叉树:树上任一结点的左子树和右子树的深度之差不超过1

3.二叉树的存储结构

3.1 二叉树的顺序存储

用一组连续存储单元自上而下,自左到右存储树上的结点元素。比较适合完全二叉树和满二叉树。对于一般的二叉树,需添加一些不存在的空结点。

#define MaxSize 100
struct TreeNode{
   
   
ElemType value; //结点中的数据元素
bool isempty;   //结点是否为空,当所存储的二叉树不是完全二叉树的时候使用这个。
}
TreeNode t[MaxSize];

image.png

如果是非完全二叉树,那么为了找到他的左孩子,右孩子,父结点,我们仍要按照完全二叉树的存储结构让序号对应起来,唯一不同的点是,我们无法根据序号,判定是否存在左孩子还是右孩子了,所以我们使用bool类型isempty,来实现判断

3.2 二叉树的链式存储

typedef struct BiTNode{
   
   
    ElemType data;
    struct BiTNode *lchild,*rchild; //左孩子指针,右孩子指针
}BiTNode,*BiTree;

在二叉链表中,链表的头指针T指向根节点。T->data表示根结点的值
image.png

n个结点的二叉链表共有n+1个空链域

每个结点都有2个指针(链域),一共有2n个链域,但是使用的链域是结点数-1,即n-1,所以2n-n+1=n+1,有n+1个空链域,这些空链域用来构造线索二叉树

但是如果想找到指定结点的父节点,只能从根开始遍历寻找,
改进方法是加上一个父节点指针,struct BiTNode *parent; 父节点指针,改进之后的链表就是三叉链表

相关文章
|
5月前
|
存储 C语言
c语言——二叉树
二叉树的概念在这里就不进行过多的赘述,那么主要说一下我认为重要的部分,第一点就是二叉树里面部分概念的理解:就比如说,你对于如何构建二叉树,掌握的十分深刻,但刷题的时候对于一些题目所给的概念不清楚,导致看不明白题目,这课不好,二叉树的概念如下图所示,其实都很简单,主要是当给他的名字时,你明不明白。还有对于满二叉树与完全二叉树。
82 0
|
8月前
|
算法 Java
算法系列之数据结构-Huffman树
Huffman树(哈夫曼树)又称最优二叉树,是一种带权路径长度最短的二叉树,常用于信息传输、数据压缩等方面。它的构造基于字符出现的频率,通过将频率较低的字符组合在一起,最终形成一棵树。在Huffman树中,每个叶节点代表一个字符,而每个字符的编码则是从根节点到叶节点的路径所对应的二进制序列。
175 3
 算法系列之数据结构-Huffman树
|
8月前
|
存储 自然语言处理 数据库
【数据结构进阶】AVL树深度剖析 + 实现(附源码)
在深入探讨了AVL树的原理和实现后,我们不难发现,这种数据结构不仅优雅地解决了传统二叉搜索树可能面临的性能退化问题,还通过其独特的平衡机制,确保了在任何情况下都能提供稳定且高效的查找、插入和删除操作。
575 19
|
10月前
|
存储 C++
【C++数据结构——树】哈夫曼树(头歌实践教学平台习题) 【合集】
【数据结构——树】哈夫曼树(头歌实践教学平台习题)【合集】目录 任务描述 相关知识 测试说明 我的通关代码: 测试结果:任务描述 本关任务:编写一个程序构建哈夫曼树和生成哈夫曼编码。 相关知识 为了完成本关任务,你需要掌握: 1.如何构建哈夫曼树, 2.如何生成哈夫曼编码。 测试说明 平台会对你编写的代码进行测试: 测试输入: 1192677541518462450242195190181174157138124123 (用户分别输入所列单词的频度) 预
244 14
【C++数据结构——树】哈夫曼树(头歌实践教学平台习题) 【合集】
|
10月前
|
Java C++
【C++数据结构——树】二叉树的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现二叉树的基本运算。​ 相关知识 创建二叉树 销毁二叉树 查找结点 求二叉树的高度 输出二叉树 //二叉树节点结构体定义 structTreeNode{ intval; TreeNode*left; TreeNode*right; TreeNode(intx):val(x),left(NULL),right(NULL){} }; 创建二叉树 //创建二叉树函数(简单示例,手动构建) TreeNode*create
205 12
|
10月前
|
C++
【C++数据结构——树】二叉树的性质(头歌实践教学平台习题)【合集】
本文档介绍了如何根据二叉树的括号表示串创建二叉树,并计算其结点个数、叶子结点个数、某结点的层次和二叉树的宽度。主要内容包括: 1. **定义二叉树节点结构体**:定义了包含节点值、左子节点指针和右子节点指针的结构体。 2. **实现构建二叉树的函数**:通过解析括号表示串,递归地构建二叉树的各个节点及其子树。 3. **使用示例**:展示了如何调用 `buildTree` 函数构建二叉树并进行简单验证。 4. **计算二叉树属性**: - 计算二叉树节点个数。 - 计算二叉树叶子节点个数。 - 计算某节点的层次。 - 计算二叉树的宽度。 最后,提供了测试说明及通关代
176 10
|
10月前
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
300 3
|
12月前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
336 5
|
12月前
|
算法
数据结构之文件系统模拟(树数据结构)
本文介绍了文件系统模拟及其核心概念,包括树状数据结构、节点结构、文件系统类和相关操作。通过构建虚拟环境,模拟文件的创建、删除、移动、搜索等操作,展示了文件系统的基本功能和性能。代码示例演示了这些操作的具体实现,包括文件和目录的创建、移动和删除。文章还讨论了该算法的优势和局限性,如灵活性高但节点移除效率低等问题。
227 0
|
12月前
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
243 59

热门文章

最新文章

下一篇
开通oss服务