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

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

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

  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. 二叉树遍历、算法实现,全部默认用二叉链表

相关推荐
刘马想放假5 小时前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠1 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦8 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠9 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾9 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres8219 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q9 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒9 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记9 天前
单项不带头不循环链表
数据结构·链表
小糯米6019 天前
JS 数组
数据结构·算法·排序算法