美文网首页
数据结构-二叉树

数据结构-二叉树

作者: coderchenhao | 来源:发表于2020-07-27 23:39 被阅读0次

什么是二叉树?

对于每个父节点来说,最多有俩个孩子节点,分别为左孩子节点和右边孩子节点。没有父节点的节点叫跟节点,没有孩子节点的节点叫叶子节点。

怎么确定二叉树?

根据前序和中序来重建二叉树

前序遍历数组的第一个节点即为根节点的信息,在中序遍历数组中查找到根节点的位置,根节点的左边是左子树,跟节点的右边是右子树,这样我们就可以得到左子树的中序遍历,右子树的中序遍历。

根据上一步得到左子树和右子树的长度,截取出前序遍历的左字数前序遍历,右子树前序遍历。依次类推,通过递归的方式,我们就能够构建出二叉树。

根据中序和后序来重建二叉树?

后序遍历数组的最后一个节点即为根节点的信息,在中序遍历数组中查找到根节点的位置,根节点的左边是左子树,跟节点的右边是右子树,这样我们就可以得到左子树的中序遍历,右子树的中序遍历。

根据上一步得到左子树和右子树的长度,截取出后序遍历的左字树后序遍历,右子树后序遍历。依次类推,通过递归的方式,我们就能够构建出二叉树。

为什么前序和后序确定不了二叉树的结构?

因为前序 和 后序遍历只能确定一棵二叉树的根节点 和 左右子树有哪些节点,而左右子树的具体结构并不能确定。

二叉树

如图所示,图片中的俩棵二叉树的前序遍历都为123,后序遍历都为321。

二叉树的遍历

前序遍历

对于一个二叉树来言,前序遍历 是先遍历父节点,然后再遍历左孩子节点,然后遍历右孩子节点。这里需要注意的是,如果左孩子节点还有孩子节点或者右孩子还有孩子节点,则按照上面的规则再依次遍历。

中序遍历

对于一个二叉树来言,中序遍历 是先遍历左孩子节点,然后再遍历父节点,然后遍历右孩子节点。这里需要注意的是,如果左孩子节点还有孩子节点或者右孩子还有孩子节点,则按照上面的规则再依次遍历。

后序遍历

对于一个二叉树来言,后序遍历 是先遍历左孩子节点,然后再遍历右孩子节点,然后遍历父节点。这里需要注意的是,如果左孩子节点还有孩子节点或者右孩子还有孩子节点,则按照上面的规则再依次遍历。

实战题目

  1. 牛客网-重建二叉树

博主微信公众号

<img src="https://gitee.com/chenhaogit/blogimages/raw/master/xsj/wzgzh-8cm.jpg" style="float:right"/>

相关文章

  • 数据结构 - 概要

    数组 链表 堆/栈/队列 树 数据结构 - 二叉树数据结构 - 二叉查找树数据结构 - 平衡二叉树数据结构 - A...

  • 关于函数递归和迭代的转化, 及尾递归相关知识的接触和思考

    javascript实现数据结构: 树和二叉树,二叉树的遍历和基本操作 js 二叉树 【数据结构与算法】深入浅出递...

  • 二叉树非递归遍历

    二叉树的非递归遍历 二叉树是一种非常重要的数据结构,很多其它数据结构都是基于二叉树的基础演变而来的。对于二叉树,有...

  • 二叉树的遍历

    数据结构算法 二叉树的遍历

  • python实现二叉树的遍历

    二叉树是一种非常重要的数据结构,很多其它数据结构都是基于二叉树的基础演变而来的。对于二叉树,有深度遍历和广度遍历,...

  • IOS基础知识-算法与数据结构篇

    数据结构 通常可以分为四类: 数据结构的存储方式: 链表可分为: 什么是树 什么是二叉树 二叉树遍历 在二叉树的一...

  • 数据结构

    数据结构 数据结构概念 顺序表 链表 队列 栈 二叉树 常用排序算法

  • 2018-05-11 二叉树的三种遍历方法

    二叉树是一种非常重要的数据结构,很多其它数据结构都是基于二叉树的基础演变而来的。对于二叉树,有前序、中序以及后序三...

  • 数据结构之二叉树(一)——绪论

    前言 二叉树是数据结构中一种重要的数据结构,也是树表家族最为基础的结构,包括完全二叉树、满二叉树、二叉查找树、AV...

  • MySQL索引

    索引是帮助MySQL高效获取数据的排好序的数据结构 索引数据结构: 二叉树 红黑树 哈希 B-Tree 二叉树容易...

网友评论

      本文标题:数据结构-二叉树

      本文链接:https://www.haomeiwen.com/subject/bjkxrktx.html