数据结构-树的概述

前言

最近学习数据结构,把自己整理的笔记记录起来。方便复习查看。如果有帮助到你,点个赞,共勉!!!

一、树的概述

树是一种非线性的数据结构,存储的是具有“一对多”关系的数据元素的集合,树有多个指向的节点,所以非线性数据结构。

二、树的专用术语

image-20201230225622386

  • 节点
  • 根节点 :如果一个结点没有父结点,那么这个结点就是整棵树的根结点。
  • 父节点
  • 子节点
  • 叶子节点 (没有子节点的节点)
  • 节点的权(节点值)
  • 路径(从 root 节点找到该节点的路线)
  • 层次:一棵树的深度(高度)是树中结点所在的最大的层次。
  • 度:结点拥有的子树的数量是为树的度。
  • 子树
  • 空树:树中没有结点。
  • 树的高度(最大层数)
  • 森林 :多颗子树构成森林,多个互不相交的树组成的集合被称为森林

三、二叉树的概念

每个节点最多只能有两个子节点的一种形式称为二叉树。

二叉树的子节点分为左节点和右节点

image-20201230230637567

经过前人的总结,二叉树具有以下几个性质:

  1. 二叉树中,第 i 层最多有 2^(i-1) 个结点。
  2. 如果二叉树的深度为 K,那么此二叉树最多有 2^K - 1 个结点。
  3. 二叉树中,终端结点数(叶子结点数)为 n0,度为 2 的结点数为 n2,则 n0 = (n2) + 1。

满二叉树

如果该二叉树的所有叶子节点都在最后一层,二叉树中除了叶子结点,每个结点的度都为 2,则此二叉树称为满二叉树。

image-20201230230436355

满二叉树除了满足普通二叉树的性质,还具有以下性质:

  1. 满二叉树中第 i 层的节点数为 2^(n-1) 个。
  2. 深度为 k 的满二叉树必有 2^k - 1 个节点 ,叶子数为 2^(k-1)。
  3. 满二叉树中不存在度为 1 的节点,每一个分支点中都两棵深度相同的子树,且叶子节点都在最底层。
  4. 具有 n 个节点的满二叉树的深度为 log2(n+1)。

完全二叉树

如果二叉树中除去最后一层节点为满二叉树,且最后一层的结点依次从左到右分布,则此二叉树被称为完全二叉树。叶子节点只存在与最后两层。

image-20201230230624402

完全二叉树除了具有普通二叉树的性质,它自身也具有一些独特的性质,比如说,n 个结点的完全二叉树的深度为 ⌊log2n⌋+1。

⌊log2n⌋ 表示取小于 log2n 的最大整数。例如,⌊log24⌋ = 2,而 ⌊log25⌋ 结果也是 2。

对于任意一个完全二叉树来说,如果将含有的结点按照层次从左到右依次标号(如图 3a)),对于任意一个结点i,完全二叉树还有以下几个结论成立:

  1. 当 i>1 时,父亲结点为结点 [i/2] 。(i=1 时,表示的是根结点,无父亲结点)
  2. 如果 2i>n(总结点的个数) ,则结点 i 肯定没有左孩子(为叶子结点);否则其左孩子是结点 2i 。
  3. 如果 2i+1>n ,则结点 i 肯定没有右孩子;否则右孩子是结点 2i+1 。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值