返回顶部
首页 > 资讯 > 前端开发 > html >怎么理解二叉树
  • 325
分享到

怎么理解二叉树

2024-04-02 19:04:59 325人浏览 安东尼
摘要

本篇文章为大家展示了怎么理解二叉树,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。大白话讲解二叉树比如现在有个数组,存放了很多用户的名字,需要从这个数组中找到包含指定

本篇文章为大家展示了怎么理解二叉树,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

大白话讲解二叉树

比如现在有个数组,存放了很多用户的名字,需要从这个数组中找到包含指定的用户名,最快的方式是什么?

我们会想到二分查找,虽然这种方式很快,但要达到最快还需要有个条件:数组有序。

如果我们能把插入用户名的时候直接给他排序,那最后的结构就是有序结构。

因此有人设计了一种数据结构:二叉查找树,也叫做二叉树。

如下图所示:这是一种二叉树结构。

怎么理解二叉树

二叉树

根据上文中的例子的,假定 Herry 在最上面,下面有  Alice,Mike,Ivy,Tom,从左到右,从上到下来看的话,最后的排序是:Alice->Herry->Ivy->Mike->Tom,确实是按照字母顺序排的。

怎么理解二叉树


名字排序说明

其中有四个术语需要说明:节点、左节点、右节点、根节点。

其中每个红色圆球都算一个节点,节点左下边相连接的节点叫做左节点,而右边相连的叫做右节点。比如 Alice 被称作 Herry 节点的左节点,Mike  被称作 Herry 的右节点。而根节点只会有一个,属于最上面的节点,上图中的 Herry 就是根节点。

对于其中每个节点,左子节点的值都比它小,而右子节点的值都比它大。比如 Alice < Herry < Mike。

假设现在我们想要查找 Ivy,首先检查根节点,发现比 Herry 大,所以往下继续找,找到了根节点的右节点 Mike,再继续找,比 Mike 小,所以找  Mike 的左节点,正好找到 Ivy。

二叉查找树中查找节点时,平均运行时间是 O(logn),最糟糕的情况下所需时间为 O(n); 而在有序数组中查找时,及时最糟糕的情况,二分查找最多也是  O(logn),所以你可能会觉得,二分查找比二叉查找要快很多。但是二叉查找树的插入和删除操作的速度是要快很多的。这里我们做一个对比:

怎么理解二叉树

二叉树与二分查找算法对比

但是二叉树也有缺点:

  • 不能随机访问。比如想要查找第 10 个元素,是不能返回第十个元素的,但是数组就可以通过下标索引找到。

  • 二叉树存在不平衡的情况,比如以根节点为中间的界限,发现右边的节点数远超左边的节点数,那么左右不平衡,查找的效率就很低了。如下图所示:

怎么理解二叉树


右边节点数远大于左边节点数

那有没有平衡的二叉树呢?当然有,那就是红黑树,限于篇幅和侧重点,这个放到下篇再讲吧

二叉树中的含义

二叉树定义

大白话说二叉树就是每个节点只能有两颗子树,且有左右之分。

来看看专业定义:二叉树是 n(n>=0 )  个结点的有限集合,该集合或者为空集(称为空二叉树),或者由一个根结点和两棵互不相交的、分别称为根结点的左子树和右子树组成。

二叉树有 5 种形态

空二叉树。

怎么理解二叉树

只有一个根节点的二叉树。

怎么理解二叉树

只有左子树

怎么理解二叉树

只有右子树。

怎么理解二叉树

完全二叉树。

怎么理解二叉树

节点的度

定义:节点拥有的子树数目称为节点的度。

我们来看下图就一目了然了。

怎么理解二叉树

mark

比如节点 B 的度为 2,节点 E 的度 为 1.

而树的度就是所有节点的度的最大值,也就是 2。

节点层次

如下图所示:根节点为第一层,依次类推。

怎么理解二叉树

二叉树的特点

每个节点最多有颗子树,所以二叉树中不存在度大于 2 的节点。

左右子树是有顺序的,次序不能任意颠倒。

即使某个节点只有一颗子树,也是需要区分它是左子树还是右子树。

二叉树的遍历

二叉树的遍历:从二叉树的根节点出发,按照某种次序依次访问二叉树中的所有节点,使得每个节点都能被访问一次,且仅被访问一次。

二叉树的访问次序可以分为四种:

  • 前序遍历。

  • 中序遍历。

  • 后续遍历。

  • 层序遍历。

前序遍历:通俗的说就是从二叉树的根结点出发,当第一次到达结点时就输出结点数据,按照先向左再向右的方向访问。

中序遍历:就是从二叉树的根结点出发,当第二次到达结点时就输出结点数据,按照先向左再向右的方向访问。

后序遍历:就是从二叉树的根结点出发,当第三次到达结点时就输出结点数据,按照先向左再向右的方向访问。

层次遍历:就是按照树的层次自上而下的遍历二叉树。

怎么理解二叉树

mark

按照前序遍历的结果就是 BADCE。

按照中序遍历的结果就是 ABCDE。

按照后续遍历的结果就是 ACEDB。

按照层次遍历的结果就是 BADCE。

上述内容就是怎么理解二叉树,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网html频道。

--结束END--

本文标题: 怎么理解二叉树

本文链接: https://lsjlt.com/news/83414.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么理解二叉树
    本篇文章为大家展示了怎么理解二叉树,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。大白话讲解二叉树比如现在有个数组,存放了很多用户的名字,需要从这个数组中找到包含指定...
    99+
    2024-04-02
  • 树,二叉树(完全二叉树,满二叉树)概念图解
    目录1、树的定义2、树的概念  3、二叉树   4、二叉树遍历5、满二叉树 6、完全二叉树 总结1、树的定义 树是n个结点...
    99+
    2024-04-02
  • 什么是二叉树与多叉树
    这篇文章主要讲解了“什么是二叉树与多叉树”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“什么是二叉树与多叉树”吧!一、树状结构1、数组与链表数组结构数组存储是...
    99+
    2024-04-02
  • 怎么使用二叉树
    这篇文章主要介绍“怎么使用二叉树”,在日常操作中,相信很多人在怎么使用二叉树问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用二叉树”的疑惑有所帮助!接下来,请跟着小编一...
    99+
    2024-04-02
  • 怎么理解并掌握Java二叉查找树
    本篇内容主要讲解“怎么理解并掌握Java二叉查找树”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解并掌握Java二叉查找树”吧!一、介绍二叉查找树,英文全...
    99+
    2024-04-02
  • 完全二叉树和线索二叉树是什么
    完全二叉树和线索二叉树是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。完全二叉树什么叫完全二叉树呢?在说到完全二叉树之前,我们先说另外一个名词:“满二叉树”。像我们之前...
    99+
    2023-06-20
  • Python树表查找(二叉排序树、平衡二叉树)
    目录什么是树表查询?1. 二叉排序树1.1 构建一棵二叉排序树1.2 二叉排序树的数据结构1.3 实现二叉排序树类中的方法:3. 平衡二叉排序树3.1 二叉平衡排序树的数据结构4. ...
    99+
    2023-01-07
    python建立二叉排序树 二叉排序树python实现 python实现平衡二叉树遍历
  • Python二叉树怎么实现
    本篇内容介绍了“Python二叉树怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Python实现二叉树Python实现二叉树可以使用...
    99+
    2023-07-06
  • 二叉搜索树
    💕人生没有太晚的开始,所有的时刻都是七点。 —— 温妮 · 普赖弗曼💕 🐼作者:不能再留遗憾了 🎆专栏:Java学习 Ὡ...
    99+
    2023-09-01
    java 算法 数据结构
  • 怎么用VBS模拟二叉树
    这篇文章给大家分享的是有关怎么用VBS模拟二叉树的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。数据结构知识: 二叉树中序便历可以用来做排序 而VBS里面恰恰就没有现成的排序方法,因此我写了一个用VBS的二叉树,来...
    99+
    2023-06-08
  • 怎么解析python二叉树的右视图
    这篇文章给大家介绍怎么解析python二叉树的右视图,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。二叉树的右视图题目描述给定一棵二叉树,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。示例:输...
    99+
    2023-06-19
  • C++超详细讲解树与二叉树
    目录树树的定义树的名词解释树的表示树的存储结构二叉树的概念及结构二叉树的概念二叉树的性质二叉树的存储结构顺序存储结构链式存储结构树 树的定义 Q:什么是树 A:树是一种 非线性 的数...
    99+
    2024-04-02
  • Java中关于二叉树的概念以及搜索二叉树详解
    目录一、二叉树的概念为什么要使用二叉树?树是什么?树的相关术语!根节点路径父节点子节点叶节点子树访问层(深度)关键字满二叉树完全二叉树二叉树的五大性质二、搜索二叉树插入删除hello...
    99+
    2024-04-02
  • python二叉树的最大深度该怎样理解
    这期内容当中小编将会给大家带来有关python二叉树的最大深度该怎样理解,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。二叉树的最大深度1 题目给定一个二叉树,找出其最大深度。二叉树的深度为根节点到最远叶子...
    99+
    2023-06-19
  • C++怎么实现二叉树及堆
    这篇文章给大家分享的是有关C++怎么实现二叉树及堆的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1 树树是一种非线性数据结构,它是由n个有限结点组成的具有层次关系的集合。把它叫树是因为它是根朝上,叶子朝下的来上图...
    99+
    2023-06-14
  • C++怎么实现平衡二叉树
    本篇内容介绍了“C++怎么实现平衡二叉树”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!平衡二叉树Given a binary tree, d...
    99+
    2023-06-20
  • PHP怎么计算二叉树坡度
    本篇内容介绍了“PHP怎么计算二叉树坡度”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一个树某结点的坡度就是该结点左子树的结点之和和右子树结...
    99+
    2023-06-20
  • Java平衡二叉树怎么实现
    本篇内容主要讲解“Java平衡二叉树怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java平衡二叉树怎么实现”吧!什么是二叉搜索树简单来说,就是方便搜索的二叉树,是一种具备特定结构的二叉...
    99+
    2023-06-29
  • Java排序二叉树怎么定义
    这篇文章主要介绍了Java排序二叉树怎么定义的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java排序二叉树怎么定义文章都会有所收获,下面我们一起来看看吧。排序二叉树概念二叉排序树(Binary Sort Tr...
    99+
    2023-06-30
  • 二叉搜索树(C++)
    二叉搜索树 概念二叉搜索树的应用二叉搜索树的实现K模型基本结构和函数声明接口实现①find——查找关键码②Insert——插入关键码③Erase——删除关键码(==重点==)时间复杂度 源码(整体)非递归递归 ...
    99+
    2023-08-30
    c++
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作