树与二叉树--二叉树的存储结构

二叉树一共有两种主流存储方式:顺序存储、链式存储

一、顺序存储结构(数组存储)

  1. 存储规则

按照完全二叉树层序编号,从上到下、从左到右依次存入数组下标。

规定:数组下标从 1 开始

  • 编号 `i` 结点

  • 左孩子:`2i`

  • 右孩子:`2i+1`

  • 父结点:`i/2`

空结点用特殊值(0/∅)占位。

  1. 适用场景

只适合完全二叉树、满二叉树

  • 空间利用率极高,没有浪费

  • 查找父子结点极快,公式直接算

  1. 缺点

普通二叉树(歪树)会大量浪费数组空间

最坏单支树,n 个结点却需要 2ⁿ 空间,极度低效。


二、链式存储结构

  1. 结点结构

每个结点包含三部分:

  1. 数据域 data:存放结点值

  2. 左孩子指针 lchild:指向左子树根

  3. 右孩子指针 rchild**:指向右子树根

Java 结点代码:

java 复制代码
class TreeNode{
    int data;
    TreeNode left;
    TreeNode right;
}
  1. 特点
  • 任意二叉树都适用,不浪费空间

  • 找孩子方便,找父结点麻烦(需要遍历)

  • 根结点指针唯一标识整棵二叉树

  1. 附加:三叉链表

在二叉链表基础上增加父指针 parent

  • 优点:找父结点、找祖先都很快

  • 缺点:多占用存储空间


三、两种存储对比

  1. 顺序存储
  • 优点:查找父子关系方便、随机访问快

  • 缺点:浪费空间、只适合完全二叉树

  • 结构:数组

  1. 二叉链表存储
  • 优点:灵活、任意二叉树通用、无空间浪费

  • 缺点:无法直接找双亲,只能遍历

  • 结构:指针链表


四、结论

  1. n 个结点的二叉链表,空指针域个数 = n + 1

  2. 顺序存储严格依赖完全二叉树编号性质

  3. 二叉树遍历、算法实现,全部默认用二叉链表

相关推荐
2401_872418787 小时前
算法入门:数据结构-堆
数据结构·算法
不会就选b11 小时前
数据结构之顺序表和链表的OJ题(上)
数据结构·链表
啦啦啦啦啦zzzz14 小时前
数据结构:二叉树的线索化
数据结构·算法
如竟没有火炬15 小时前
寻找峰值——二分
java·开发语言·数据结构·python·算法·散列表
he___H17 小时前
B、B+树和vue部分知识
数据结构·vue.js·b树
hai31524754318 小时前
结构化编程:AI工业化编程的探索
数据结构·自然语言处理·硬件工程·动态规划·集成学习
2401_8685347818 小时前
2026年5月系统分析
数据结构·python·tornado
袋鼠云数栈19 小时前
数栈 V7.0 多模态数据智能平台:打造 AI-Ready 的企业数据底座
大数据·数据结构·数据库·人工智能·数据治理·多模态
迈巴赫车主20 小时前
优先队列(PriorityQueue)
数据结构·算法
Boom_Shu20 小时前
构造函数程序
数据结构·算法