《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

这篇具有很好参考价值的文章主要介绍了《数据结构C语言版》——树、森林与二叉树的转换(超详图解)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

哈喽!这里是一只派大鑫,不是派大星。本着基础不牢,地动山摇的学习态度,从基础的C语言语法讲到算法再到更高级的语法及框架的学习。更好地让同样热爱编程(或是应付期末考试 狗头.jpg)的大家能够在学习阶段找到好的方法、路线,让天下没有难学的程序(只有秃头的程序员 2333),学会程序和算法,走遍天下都不怕!

 

目录

引言

问题引出

转换过程

树—>二叉树

森林—>二叉树

二叉树—>树

二叉树—>森林

 总结


引言

在数据结构的考试中,无论是本科期末考试还是考研,对树的考察一定是重点,其中对树和二叉树之间的转换也是热门考点,因为不涉及写代码,多数以画图或是选择题的形式出现,所以较为简单,但仍需认真学习。

本文对树、森林与二叉树之间的相互转换的过程和方法进行讲解,相信哪怕是小白的你,在看完文章后也能豁然开朗。

妈妈再也不担心我不会手写数据结构了

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

 对于树、二叉树的介绍在本文不再进行重述,有需要的读者可以查看博主的上一篇关于二叉树详解的文章  《数据结构C语言版》——二叉树详解(图文并茂)

 

问题引出

 前面已经讲过了树的定义和存储结构,对树来说,在满足树的条件下可以是任意形状,一个结点可以有任意多个孩子,显然对树的处理要更复杂,去研究树的性质和算法就不太容易了。但是对于二叉树,尽管它也是树,但由于每个结点最多只能有左孩子和右孩子,面对的变化就少了很多。如果我们能把树转化为二叉树,那么就会方便很多。

转换过程

在树的存储结构那一讲中,提到了树的孩子兄弟表示法可以将一棵树用二叉链表进行存储,所以借助二叉链表,树和二叉树可以相互转换,同样的,森林也可以和二叉树相互转换。

树—>二叉树

假设我们的树是这样的。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

 

将树转化为二叉树的步骤如下:

(1)加线。在所有兄弟结点之间加一条连线。如下所示。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

(2)去线,对树中每个结点,只保留它与第一个孩子结点的连线,删除它与其他孩子结点之间的连线。如下所示。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

(3)层次调整。以树的根结点为核心,将整棵树顺时针旋转一定的角度,使之层次分明。如下所示。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

 

森林—>二叉树

假设森林是这样的。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

 

将森林转化为二叉树的步骤如下:

(1)把每个树转换为二叉树。如下所示。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

(2)第一棵二叉树不动,从第二棵二叉树开始,依次把后一颗二叉树的根结点作为前一颗二叉树的根结点的右孩子,用线链接起来。如下所示。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

 

二叉树—>树

二叉树转换为树其实就是树转换为二叉树的逆过程,反过来做而已。

假设有这么一颗二叉树。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

 

将二叉树转化为树的步骤如下:

(1)加线。若某结点的左孩子结点存在,则将这个左孩子的右孩子结点,右孩子的右孩子结点....(也就是将左孩子的n个右孩子结点都作为此节点的孩子)。将该结点与这些右孩子结点用线连接起来。如下所示。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

(2)去线。删除原二叉树中所有结点与其右孩子结点的连线。如下所示。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

(3)层次调整。使之结构层次分明。如下所示。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

 

二叉树—>森林

判断一颗二叉树能够转换为一棵树还是森林很简单,如果这棵二叉树的根结点没有右孩子就是树,有右孩子就转化为森林。

假设有这么一颗二叉树。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

 

将二叉树转化为森林的步骤如下:

(1)从根结点开始,若右孩子存在,则把与右孩子结点的连线删除。如下所示。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

(2)再看分离后的二叉树,若右孩子存在,则连线删除...直到所有右孩子连线都被删除为止,得到分离的二叉树。如下所示。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

(3)最后将分离的二叉树转换为树即可。如下所示。

《数据结构C语言版》——树、森林与二叉树的转换(超详图解)

 总结

        树、森林与二叉树之间的转换就是这样的,文、图给出的是详细过程,也是最基础的过程。

        如果对“孩子兄弟”表示法比较熟悉的话,可以直接对其进行转换,也就是一个结点的第一个孩子变成该结点的左孩子,其他的孩子(即左孩子的兄弟)都依次连接在该结点的右边。

使用“孩子兄弟”表示法来进行转换省去加线、取线的过程,使转换更为直接。

        知识学习完了不要忘记做一些练习题来巩固基础~~~文章来源地址https://www.toymoban.com/news/detail-496363.html

到了这里,关于《数据结构C语言版》——树、森林与二叉树的转换(超详图解)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【数据结构】树与二叉树

    树是一种 非线性的数据结构 ,它是由n(n=0)个有限结点组成一个具有层次关系的集合。 把它叫做树是因为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的 。它具有以下的特点: 有一个特殊的结点,称为根结点,根结点没有前驱结点 除根结点外,其余结点被分

    2024年02月11日
    浏览(45)
  • 数据结构--树与二叉树

    树的定义 树是n(n =0)个节点的有限集。当n=0 时,称为空树 在任意一棵非空树中应满足 有且仅有一个特定的称为根的结点 当n1 时,其余节点可分为m(m0) 个互不相交的有限集T1,T2……Tm,其中每个集合本身又是一棵树,并且称为根的子树 树是一种逻辑结构,也是一种分层结构 树的

    2024年02月22日
    浏览(45)
  • [数据结构] 树与二叉树

    树是由 (n(n geq 0)) 个节点组成的有限集。当 (n = 0) 时,称为空树。 任意一棵非空树应满足以下两点: (1)有且仅有一个特定的称为根的节点; (2)当 (n 1) 时,其余节点可分为 (m(m0)) 个互不相交的有限集 (T_1, T_2, dots, T_m) ,其中每个集合本身又是一棵树,称为根的

    2024年03月09日
    浏览(42)
  • 数据结构_树与二叉树

    目录 1. 树的基本概念 1.1 树的定义 1.2 基本术语 1.3 树的性质 1.4 相关练习 2. 二叉树的概念 2.1 二叉树的概念及其主要特性 2.2 二叉树的存储结构 2.2.1 顺序存储结构 2.2.2 链式存储结构 2.3 相关练习 3. 二叉树的遍历和线索二叉树 3.1 二叉树的遍历 3.1.1 先序遍历 3.1.2 中序遍历 3.1

    2024年02月04日
    浏览(46)
  • 【数据结构】树与二叉树(中)

    目录 前言: 一、顺序存储结构: 二、堆: 1.堆的性质: 2.堆的性质: 3.堆的实现: Ⅰ.堆的初始化:  Ⅱ.堆的插入(含向上调整):  Ⅲ.堆的删除(含向下调整算法): Ⅳ.取堆顶的数据: Ⅴ.堆中的数据个数: Ⅵ.堆的判空:  Ⅶ.堆的销毁: 总结:         上篇文章中,

    2024年02月16日
    浏览(47)
  • 数据结构:图文详解 树与二叉树(树与二叉树的概念和性质,存储,遍历)

    目录 一.树的概念 二.树中重要的概念 三.二叉树的概念 满二叉树 完全二叉树 四.二叉树的性质 五.二叉树的存储 六.二叉树的遍历 前序遍历 中序遍历  后序遍历  树是一种 非线性数据结构 ,它由节点和边组成。树的每个节点可以有零个或多个子节点,其中一个节点被指定为

    2024年02月04日
    浏览(49)
  • 【数据结构与算法】树与二叉树

    除了之前我们讲的栈、队列、链表等线性结构,数据结构中还有着一对多的 非线性结构 ——— 树 。 树是有 n 个结点组成的有限集,当n=0时为空树,在任意一颗非空树中,有且仅有一个 特定的根结点 ;当n1时,其余结点又可以分为一棵树,称为根的 子树 。 如下图所示: A为

    2023年04月09日
    浏览(50)
  • 数据结构与算法——树与二叉树

    😊各位小伙伴久等了,本专栏新文章出炉了!!! 我又回来啦,接下来的时间里,我会持续把数据结构与算法专栏更新完。 👉树型结构👈 是一类重要的 ✍非线性数据结构 ,其中以树和二叉树最为常用,直观来看,树是以分支关系定义的层次结构。树型结构在客观世界中

    2024年02月11日
    浏览(46)
  • 【数据结构】树与二叉树(十三):递归复制二叉树(算法CopyTree)

      二叉树是一种常见的树状数据结构,它由结点的有限集合组成。一个二叉树要么是 空集 ,被称为 空二叉树 ,要么由一个根结点和两棵不相交的子树组成,分别称为 左子树 和 右子树 。每个结点最多有两个子结点,分别称为左子结点和右子结点。 引理5.1:二叉树中层数

    2024年02月01日
    浏览(40)
  • 【数据结构】24王道考研笔记——树与二叉树

    树是n个结点的有限集合,n=0时,称为空树。非空树满足: 除了根节点外,任何一个结点都有且仅有一个前驱 结点的层次(深度):从上往下数 结点的高度:从下往上数 树的高度(深度):总共有多少层 结点的度:有几个孩子(分支) 树的度:各节点的度的最大值 森林:

    2024年02月13日
    浏览(50)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包