目录
前言
这篇博客主要介绍二叉树的链式存储结构。
1.二叉树的链式存储
上篇文章中介绍了二叉树的顺序存储结构,在最坏的情况下,比如二叉树仅有左子树或者右子树的时候,我们仍然需要为不存在的节点分配大量的存储空间,这无疑会造成存储空间的浪费。考虑到二叉树的三要素:数据域、右子树指针、左子树指针,我们可以考虑使用链式存储来表示二叉树。
当我们使用数据域、左右子树指针表示二叉树的结构时,得到的二叉树链表成为二叉链表。我们还可以再二叉链表的基础上增加一个父结点的数据域,这样得到的二叉树链表称为三叉链表。
二叉链表和三叉链表的存储结构如下图所示:
图1.二叉链表和三叉链表的表示
2.二叉链表的表示和实现
1.定义
typedef char TelemType;
typedef int Status;
typedef struct BiTNode{
TelemType data;//数据域
struct BiTNode * lchild,*rchild;//左右孩子指针
}BiTNode,*BiTree;
2.创建
// 创建二叉树
Status creat