树的概念和定义.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
(7) FirstChild(Tree,x): 树Tree存在, x是Tree中的某个结点。若x为非叶子结点,则返回它的第一个孩子结点, 否则返回“空”。 (8) NextSibling(Tree,x): 树Tree存在,x是Tree中的某个结点。若x不是其双亲的最后一个孩子结点,则返回x后面的下一个兄弟结点, 否则返回“空”。 二叉树的定义与基本操作 二叉树的性质 用C语言可以这样声明二叉树的二叉链表结点的结构: typedef struct Node { DataType data;  struct Node *LChild;  struct Node *RChild;  }BiTNode, *BiTree; 有时,为了便于找到父结点,可以增加一个Parent域, Parent域指向该结点的父结点。 该结点结构如下: RChild parent Data LChild * 第十四讲 树的概念与定义 树是n(n≥0)个结点的有限集合T。当n=0时,称为空树;当n0时, 该集合满足如下条件:  (1) 其中必有一个称为根(root)的特定结点,它没有直接前驱,但有零个或多个直接后继。  (2) 其余n-1个结点可以划分成m(m≥0)个互不相交的有限集T1,T2,T3,…,Tm,其中Ti又是一棵树,称为根root的子树。 每棵子树的根结点有且仅有一个直接前驱,但有零个或多个直接后继。 图6.1 树的图示方法 结点:包含一个数据元素及若干指向其它结点的分支信息。 结点的度:一个结点的子树个数称为此结点的度。  叶结点:度为0的结点,即无后继的结点,也称为终端结点。 分支结点:度不为0的结点,也称为非终端结点。  孩子结点:一个结点的直接后继称为该结点的孩子结点。 双亲结点:一个结点的直接前驱称为该结点的双亲结点。 兄弟结点:同一双亲结点的孩子结点之间互称兄弟结点。 祖先结点:一个结点的祖先结点是指从根结点到该结点的路径上的所有结点。在图6.1中,结点K的祖先是A、B、E。  子孙结点:一个结点的直接后继和间接后继称为该结点的子孙结点。在图6.1中,结点D的子孙是H、I、 J、 M。  树的度: 树中所有结点的度的最大值。  结点的层次:从根结点开始定义,根结点的层次为1,根的直接后继的层次为2,依此类推。  树的高度(深度): 树中所有结点的层次的最大值。  有序树:在树T中,如果各子树Ti之间是有先后次序的,则称为有序树。  森林: m(m≥0)棵互不相交的树的集合。将一棵非空树的根结点删去,树就变成一个森林;反之,给森林增加一个统一的根结点,森林就变成一棵树。 ADT Tree 数据对象D:一个集合,该集合中的所有元素具有相同的特性。 数据关系R: 若D为空集,则为空树。 若D中仅含有一个数据元素,则R为空集,否则R={H},H是如下的二元关系: (1) 在D中存在唯一的称为根的数据元素root, 它在关系H下没有前驱。  (2) 除root以外, D中每个结点在关系H下都有且仅有一个前驱。 基本操作:  (1) InitTree(Tree): 将Tree初始化为一棵空树。  (2) DestoryTree(Tree): 销毁树Tree。  (3) CreateTree(Tree): 创建树Tree。  (4) TreeEmpty(Tree): 若Tree为空, 则返回TRUE, 否则返回FALSE。  (5) Root(Tree): 返回树Tree的根。  (6) Parent(Tree, x): 树Tree存在, x是Tree中的某个结点。 若x为非根结点,则返回它的双亲, 否则返回“空”。  (9) InsertChild(Tree, p, Child):树Tree存在,p指向Tree中某个结点,非空树Child与Tree不相交。将Child插入Tree中, 做p所指向结点的子树。  (10) DeleteChild(Tree,p,i): 树Tree存在, p指向Tree中某个结点, 1≤i≤d,d为p所指向结点的度。 删除Tree中p所指向结点的第i棵子树。  (11) TraverseTree(Tree,Visit()): 树Tree存在,Visit()是对结点进行访问的函数。按照某种次序对树Tree的每个结点调用Visit()函数访问一次且最多一次

文档评论(0)

好文精选 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档