树与二叉树--二叉树的定义及其主要特性

一、二叉树的定义

二叉树是n(n≥0)个结点的有限集合,满足:

  1. 当 n=0 时,称为空二叉树。

  2. 非空时:

  • 有且仅有一个根结点;

  • 根结点的子结点分为左子树和右子树;

  • 左右子树次序不能颠倒,因此二叉树是有序树。

简单理解:

  • 每个结点最多两个孩子(0、1 或 2 个)

  • 左孩子≠右孩子,交换后就是两棵不同的树


二、二叉树的五种基本形态

  1. 空二叉树

  2. 只有根结点

  3. 根 + 左子树

  4. 根 + 右子树

  5. 根 + 左子树 + 右子树


三、二叉树的四个重要特性

特性 1

二叉树第 i 层上至多有2^(i−1) 个结点

(i ≥ 1,根为第 1 层)

特性 2

深度(高度)为 k的二叉树,最多有2^k − 1 个结点

(这就是满二叉树)

特性 3(最重要公式)

对任意一棵二叉树,若:

  • n₀:叶子结点数(度为 0)

  • n₁:度为 1 的结点数

  • n₂:度为 2 的结点数

则恒成立:

> n₀ = n₂ + 1

推导:

  1. 总结点数 n = n₀ + n₁ + n₂

  2. 总边数 = 总度数 = n₁ + 2n₂

  3. 树中:n = 总边数 + 1

联立得:n₀ = n₂ + 1

特性 4

具有 n 个结点的完全二叉树**的高度为:

> h = log₂n + 1

或等价写成

> h = log₂(n+1)


四、两种特殊二叉树

  1. 满二叉树
  • 每一层结点数都达到最大值

  • 高度 k,结点总数 = 2^k − 1

  • 所有叶子都在最底层

  • 只有度为 0 和度为 2 的结点,没有度为 1 的结点

  1. 完全二叉树
  • 除最后一层外,其他层都"满"

  • 最后一层结点靠左连续排列

  • 最多只有一个度为 1 的结点,且只有左孩子

  • 适合顺序存储(数组)


五、完全二叉树的编号性质(层序编号从 1 开始)

对编号为 i 的结点:

  1. 父结点编号: i / 2

  2. 左孩子编号:2i

  3. 右孩子编号:2i + 1

  4. 若 i > 1,是左孩子则父结点为 i/2;是右孩子则父结点为 (i−1)/2


六、易混淆点

  1. 二叉树 ≠ 度为 2 的树
  • 二叉树严格区分左右

  • 二叉树可以只有左子树或只有右子树

  1. 空树是合法二叉树

  2. 只有一个孩子时,也要明确是左还是右

相关推荐
福大大架构师每日一题1 天前
redis 8.8.0 发布:新数据结构、字段级通知、INCREX、XNACK 全面升级,8.6 到 8.8 变化一文看懂
数据结构·数据库·redis
c238561 天前
list(下)
数据结构·windows·list
CS创新实验室1 天前
当数据撞上量子:论《数据结构》课程的颠覆与新生
数据结构·量子计算
代码中介商1 天前
排序算法完全指南(八):归并排序深度详解
数据结构·算法·排序算法
kkeeper~1 天前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
2401_868534781 天前
论企业网络设计
数据结构
2401_876964131 天前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
c238562 天前
vector(下)
数据结构·算法
z落落2 天前
C# 冒泡排序+选择排序 + Array.Sort 自定义排序
数据结构·算法
无限进步_2 天前
【C++】weak_ptr、循环引用与线程安全
开发语言·数据结构·c++·算法·安全