二叉树及存储结构

定义

  1. 二叉树T:一个有穷的结点集合。
    这个集合可以为空
    若不为空,则它是由根结点和称为其左子树TL和右子树TR的两个不相交的二叉树组成
  2. 特殊的二叉树
    斜二叉树(Skewed Binary Tree)
    完美二叉树(Perfect Binary Tree)/满二叉树(Full Binary Tree)
    完全二叉树(Complete Binary Tree):有n个结点的二叉树,对树中结点按从上至下、从左到右顺序进行编号, 编号为i(1 ≤ i ≤ n)结点与满二叉树中编号为 i 结点在二叉树中位置相同
  3. 二叉树的重要性质
  • 一个二叉树第 i 层的最大结点数为: 2^(i-1),i>=1。
  • 对任何非空二叉树 T,若n0表示叶结点的个数、n2是度为2的非叶结点个数,那么两者满足关系: n0 = n2 +1。 (推导)
  • 深度为k的二叉树有最大结点总数为: 2^k-1,k >=1。
  1. 二叉树的抽象数据类型
    操作集:
    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 ):层次遍历,从上到下、从左到右
  2. 二叉树的存储结构
    1.顺序存储在这里插入图片描述
    2.链表存储
    在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值