当前位置: 首页 > news >正文

二叉树——存储结构

二叉树的存储结构

二叉树一般可以使用两种结构存储,一种是顺序结构,另一种是链式结构。

一、顺序存储

      二叉树的顺序存储是指用一组连续的存储单元依次自上而下自左至右存储完全二叉树上的结点元素,即将完全二叉树上编号为i的结点元素存储在一维数组下标为i-1的分量中。

依据二叉树的性质,完全二叉树满二叉树采用顺序存储比较合适,树中结点的序号可以唯一地反映结点之间的逻辑关系,既最大可能地节省存储空间,且可以利用数组元素的下标值确定结点在二叉树中的位置,以及结点之间的关系。但对于一般的二叉树,为了让数组下标能反映二叉树中结点之间的逻辑关系,只能添加一些并不存在的空结点大让其每个结点与完全二叉树上的结点相对照,再存储到一维数组的相应分量中。

实际就是使用数组来存储,一般使用数组只适合表示完全二叉树,因为非完全二叉树会有空间的浪费。而现实使用中只有堆才会使用数组来存储。所以二叉树顺序存储在物理上是一个数组,在逻辑上是一颗二叉树

例:二叉树的顺序存储中,一定要把二叉树的节点编号与完全二叉树对应起来

* i的左孩子     ——2i

* i的右孩子     ——2i+1

* i的父节点     ——[i/2]

在最坏情况下:高度为h且只有h个结点的单支树(所有结点只有右孩子)也至少需要2h-1个存储单元。其中0表示并不存在的空结点。

结论:二叉树的顺序结构,只适合存储完全二叉树。

二叉树的顺序存储结构描述如下:

#define MAXSIZE 20
typedef struct BiTNode {
ElemType data;             //数据域
int 1child, rchild;        //存放左、右孩子的数组下标
}BiTNode;                  //二叉树节点的类型BiTNode tree[MAXSIZE];
int n;                     //树中实际所含节点的个数
int root;                  //存放根节点的数组下标

二、链式存储

       二叉树的链式存储结构是指,用链表来表示一棵二叉树,即用链来指示元素的逻辑关系。 通常的方法是链表中每个结点由三个域组成数据域 (data)和左(lchild)、右(rchild)指针域左、右指针分别用来给出该结点左孩子和右孩子所在的链结点的存储地址 。

二叉树的链式存储结构描述如下:

typedef struct BiTNode {
ElemType data;//数据域
struct BiTNode *1child, *rchild;//左、右孩子指针
}BiTNode, *BiTree;

       所以使用不同的存储结构时,实现二叉树操作的算法也会不同,因此要根据实际应用场合(二叉树的形态和需要进行的运算)来选择合适的存储结构。容易验证,在含有n个结点的二叉链表中,含有n+ 1个空链域

http://www.lryc.cn/news/334943.html

相关文章:

  • LangChain - OpenGPTs
  • pe格式从入门到图形化显示(四)-节表
  • 路由策略与路由控制之双点双向重发布(OSPF-ISIS)实验
  • 9proxy—数据采集工具全面测评
  • 上海晶珩树莓派工业智能机械臂,亮相2024年embedded world博览会!
  • 蓝桥杯——求和
  • 设计模式:责任链模式示例
  • SpringBoot快速入门笔记(4)
  • GoPro相机使用的文件格式和频率
  • Redis Stack 安装部署
  • 【经典算法】LeetCode 5: 最长回文子串(Java/C/Python3实现含注释说明,Medium)
  • 39.Python从入门到精通—parseString 方法 Python 解析XML实例 使用xml.dom解析xml
  • 【蓝桥杯第九场小白赛】(部分)
  • 【Linux】Supervisor 基础
  • 48 全连接卷积神经网络 FCN【动手学深度学习v2】
  • pytorch中的nn.MSELoss()均方误差损失函数
  • 三国游戏(贪心 排序)
  • GPU环境安装与虚拟环境安装(适用于Windows下的李沐GPU)
  • Http Download
  • 【Android】Glide加载SVG,SVG转PNG
  • Spring、SpringMVC、Springboot三者的区别和联系
  • 一点点安全资料:网络安全扩展
  • vscode的源码插件GitHub Repositories
  • 如何定义快速开发平台框架?有何突出优势?
  • 二分练习题——奶牛晒衣服
  • python工具包【1】 -- 不同操作系统路径转换
  • JAVA中@FunctionalInterface 注解使用
  • 【Spring Cloud Alibaba】9 - OpenFeign集成Sentinel实现服务降级
  • Chrome浏览器如何跟踪新开标签的网络请求?
  • html写一个登录注册页面