数据结构笔记6 二叉树及存储结构

二叉树的定义

二叉树T:一个有穷的结点集合。
这个集合可以为空
若不为空,则它是由根结点和称为其左子树TL右子树TR的两个不相交的二叉树组成

二叉树具体五种基本形态:
在这里插入图片描述
二叉树的子树有左右顺序之分:
在这里插入图片描述
特殊二叉树
斜二叉树(Skewed Binary Tree)
在这里插入图片描述
完美二叉树(Perfect Binary Tree) 又称满二叉树(Full Binary Tree)
在这里插入图片描述
完全二叉树(Complete Binary Tree)
有n个结点的二叉树,对树中结点按从上至下、从左到右顺序进行编号,编号为i(1 ≤ i ≤ n)结点与满二叉树中编号为 i 结点在二叉树中位置相同。

二叉树几个重要性质

一个二叉树第 i 层的最大结点数为:2 i-1,i ≥ 1。
深度为k的二叉树有最大结点总数为:2 k-1,k ≥ 1。
任何非空二叉树 T,若n0表示叶结点的个数、n2是度为2的非叶结点个数,那么两者满足关系n0= n2+1
在这里插入图片描述
证明n0= n2+1:
n0+n1+n2-1= n0 * 0+n1 * 1+n2 * 2
n0-1=n2 得证

二叉树的抽象数据类型定义

类型名称:二叉树
数据对象集:一个有穷的结点集合。
若不为空,则由根结点和其左、右二叉子树组成。
重要操作有:
1、Boolean IsEmpty( BinTree BT ): 判别BT是否为空;
2、void Traversal( BinTree BT ):遍历,按某顺序访问每个结点;
3、BinTree CreatBinTree( ):创建一个二叉树。
常用的遍历方法有:
void PreOrderTraversal( BinTree BT ):先序----根、左子树、右子树;
void InOrderTraversal( BinTree BT ): 中序—左子树、根、右子树;
void PostOrderTraversal( BinTree BT ):后序—左子树、右子树、根
void LevelOrderTraversal( BinTree BT ):层次遍历,从上到下、从左到右

二叉树的存储结构

  1. 顺序存储结构
    完全二叉树:按从上至下、从左到右顺序存储
    n个结点的完全二叉树的结点父子关系:
    非根结点(序号 i > 1)的父结点的序号是 i / 2;
    结点(序号为 i )的左孩子结点的序号是 2i,(若2 i <= n,否则没有左孩子);
    结点(序号为 i )的右孩子结点的序号是 2i+1,(若2 i +1<= n,否则没有右孩子);
    (一般二叉树也可以采用这种结构,但会造成空间浪费,所以一般用链表存储)

  2. 链表存储

typedef struct TreeNode *BinTree;
typedef BinTree Position;
struct TreeNode{
ElementType Data;
BinTree Left;
BinTree Right;
}

在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值