• 树:树是n个节点的有限集,任意一颗树有且仅有一个特定的称为根的节点。
    (树是由一个根节点和若干棵子树组成的)

  • 注意:
    1、当n>0时根节点是唯一的,不可能存在多个根节点。
    2、m>0时,子树的个数是没有限制的,但它们一定是互不相交的。

  • 节点的分类:
    1、节点拥有的子树数称为节点的度,度为0的节点称为叶子结点或者终端节点。
    2、树的度是树内各节点的度的最大值。
    3、树中节点的最大层次称为数的深度或高度。

线性结构树结构
第一个数据元素:无前驱根节点:无双亲,唯一性
最后一个数据元素:无后驱叶节点:无孩子,可以有多个叶节点
中间元素:一个前驱和一个后驱中间结点:一个双亲,多个子节点
  • 树的操作
    在这里插入图片描述
  • 树的存储结构
  • 双亲表示法:
    在这里插入图片描述
    data:数据域,存储节点的数据信息
    parent:指针域,存储该节点的双亲在数组中的下标由于根节点没有双亲节点,就约定根节点的位置域设置为-1.

在这里插入图片描述
这样的存储结构,我们可以根据节点的parent指针很容易找到它的双亲节点,所用的时间复杂度为O(1),直到parent为-1时,表示找到了树节点的根。

  • 孩子表示法
    方法一:
    在这里插入图片描述
    方法二:

在这里插入图片描述
方法三:把每个节点的孩子节点排列起来,以单链表作为存储结构,则n个节点有n个孩子链表,如果是叶子结点则此单链表为空,然后n个头指针又组成一个线性表,采用顺序存储结构,存放进一个一维数组中.
在这里插入图片描述
节点结构:
1、孩子链表的孩子节点

childnext

child:数据域 ,用来存储某个节点在表头数组中的下标
next:指针域,用来存储指向某节点的下一个孩子节点的指针

2、表头数组的表头节点

datafirstchild

data:数据域,存储某节点的数据信息
firstchild:头指针域,存储该节点的孩子链表的头指针

  • 孩子兄弟表示法: 任意一颗树,它的节点的第一个孩子如果存在就是唯一的,它的右兄弟存在也是唯一的。因此,设置两个指针,分别指向该节点的第一个孩子和此节点的右兄弟
    在这里插入图片描述
    data:数据域
    firstchild:指针域,存储该节点的第一个孩子节点的存储地址
    rightsib:指针域,存储该节点的右兄弟节点的存储地址

在这里插入图片描述

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值