树与二叉树--树的性质

一、普通树的基本性质

1.树中的结点数 = 总度数 + 1

  • 每条边对应一个度数

  • 根结点没有父结点,所以少一条边

  • 公式:n = 总度数 + 1

  1. 度为 m 的树(m 叉树)第 i 层最多结点数
  • 第 1 层:1 个

  • 第 2 层:m 个

  • 第 3 层:m² 个

  • 第 i 层最多:m^(i-1)个结点

  1. 高度为 h 的 m 叉树最多结点数

-(m^h-1)/(m-1)

  1. 高度 h 与最少结点数
  • 每层至少 1 个结点

  • 最少结点数:h


二、二叉树的重要性质

性质 1

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

(i ≥ 1)

性质 2

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

(满二叉树)

性质 3

对任意一棵二叉树:

叶子结点数 n₀ = 度为 2 的结点数 n₂ + 1

即:

n_0 = n_2 + 1

性质 4

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

h = log_2(n(n(m-1)+1)

性质 5(完全二叉树父子下标关系)

对按层序编号 1~n 的完全二叉树:

  • 结点 i 的左孩子:2i

  • 结点 i 的右孩子:2i + 1

  • 结点 i 的父结点:⌊i/2⌋

  • 叶子结点一定在最后一层或倒数第二层


三、满二叉树 & 完全二叉树 区别与性质

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

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

  • 所有叶子都在最底层

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

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

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

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

  • 是顺序存储(数组)的最佳结构


四、二叉树 vs 度为 2 的有序树

  • 二叉树是严格有序:左孩子≠右孩子,交换即不同树

  • 度为 2 的普通树:子树不分左右,只看个数

  • 二叉树可以空树、只有左子树、只有右子树

  • 普通树至少 1 个结点(非空定义)


五、树、二叉树、森林之间的转换规律

1.树 ↔ 二叉树

  • 左孩子:原树的第一个孩子

  • 右孩子:原树的兄弟结点

  1. 森林 ↔ 二叉树
  • 每棵树转为二叉树

  • 依次把后一棵树的根作为前一棵树的右孩子

  1. 转换后性质
  • 树的先根遍历= 对应二叉树先序遍历

  • 树的后根遍历 = 对应二叉树中序遍历


六、高度、深度、层数的统一说明

  • 根结点层数 = 1

  • 结点深度 = 层数

  • 树的高度 = 最大层数

  • 叶子高度 = 1

  • 空树高度 = 0


七、快速记忆口诀

  1. 树结点数 = 总度数 + 1

  2. 二叉树第 i 层最多 2^(i−1)

  3. 满二叉树总数 2^k − 1

  4. 叶子数 = 度2结点数 + 1

  5. 完全二叉树高度 ⌊log₂n⌋ + 1

  6. 完全二叉树下标:左2i、右2i+1、父i/2

相关推荐
流年如夢19 小时前
单链表进阶版 -->双向链表
数据结构·链表
流年如夢20 小时前
单链表 -->增、删、查、改等详细操作
c语言·数据结构
handler011 天前
【算法模板】最小生成树:稠密图选 Prim,稀疏图选 Kruskal
c语言·数据结构·c++·算法
此生决int1 天前
快速复习之数据结构篇——栈和队列
数据结构·c++
昵称小白1 天前
子串专题部分
数据结构·算法·哈希算法
ShoreKiten1 天前
cpp考前急救
数据结构·c++·算法
诙_1 天前
C++数据结构--AVL树
数据结构
Cando学算法1 天前
欧拉回路(一笔画)
数据结构·c++·图论
图码1 天前
一文搞懂如何判断字符串是否为Pangram(全字母句)
数据结构·算法·网络安全·数字雕刻·ping++
khalil10201 天前
代码随想录算法训练营Day-43 动态规划10 | 300.最长递增子序列、674. 最长连续递增序列、718. 最长重复子数组
数据结构·c++·算法·leetcode·动态规划·子序列问题