二叉树的定义

二叉树(Binary Tree)是n(n≥0)个元素的有限集合,该集合为空或者为由一个称为“根”的元素及两个不相交的、被分别称为左子树和右子树的二叉树组成
二叉树的基本特点:

  • 每个结点最多有两棵子树
  • 左子树和右子树是有顺序的,且不可颠倒

  • 图一

    节点、度和叶子的概念

  • 1、结点
  • 二叉树中的每一个元素都称为结点。通常二叉树的许多名词借用了家族关系
    例如在上图中,2、3均是1的子结点,1是2&3的双亲,因而2、3互为“兄弟结点”

  • 2、度
  • 二叉树的度代表某个结点的孩子或者后继人的个数,1度表示只有一个孩子或者称之为单子树,2度是两个孩子或者说左右子树都有的二叉树。当然,二叉树某个结点的最大度为2.例如2的度数为2,3的度数为1

  • 叶子
  • 叶子是叶子结点的简称,叶子也就是leaf,原指网络结构中的某些计算机,它们从比较靠近中心的计算机处接收信号,而不把信号传至较远的计算机。在二叉树中叶子结点指树种处于最底端的结点,叶子结点没有子结点 例如上图中的 4、5、6均为叶子结点

    特殊二叉树


    图二

    特殊二叉树有:满二叉树完全二叉树

  • 满二叉树:
  • 在一棵二叉树中,如果所有分支结点都存在左子树和右子树,并且所有叶子结点都在同一层上,这样的一棵二叉树称之为满二叉树
    例如图二中的第一张图,即为一棵满二叉树。而第二张图的B结点由于没有右子节树,所以不是满二叉树。
    满二叉树的特点有:

    1.叶子只能出现在最下一层
    2.非叶子结点的度一定为2
    3.在同样深度的二叉树中,满二叉树的结点个数最多,叶子最多

  • 完全二叉树
  • 一棵深度为k的有n个结点的二叉树,从树中的结点按从上至下、从左至右的顺序进行编号,如果编号为i(1≤i≤n)的节点与满二叉树中编号为i的结点在二叉树中的位置相同,则这棵二叉树称为完全二叉树,如图二的第三张图。

    1.叶子结点只能出现在最下两层
    2.最下层的叶子若有结点,一定集中在左下部分
    3.倒数第二层若有叶子结点,一定都集中在右半部分
    4.如果结点度为1,则该结点只有左孩子,即不存在只有右孩子之说。
    5.同样结点数的二叉树,完全二叉树的深度最小

    二叉树&满二叉树与完全二叉树的更多相关文章

    1. 树&二叉树&&满二叉树&&完全二叉树&&完满二叉树

      目录 树 二叉树 完美二叉树(又名满二叉树)(Perfect Binary Tree) 完全二叉树(Complete Binary Tree) 完满二叉树(Full Binary Tree) 树 名称 ...

    2. 【algo&ds】【吐血整理】4.树和二叉树、完全二叉树、满二叉树、二叉查找树、平衡二叉树、堆、哈夫曼树、B树、字典树、红黑树、跳表、散列表

      本博客内容耗时4天整理,如果需要转载,请注明出处,谢谢. 1.树 1.1树的定义 在计算机科学中,树(英语:tree)是一种抽象数据类型(ADT)或是实作这种抽象数据类型的数据结构,用来模拟具有树状结 ...

    3. 找出 int 数组的平衡点 & 二叉树 / 平衡二叉树 / 满二叉树 / 完全二叉树 / 二叉查找树

      找出 int 数组的平衡点 左右两边和相等, 若存在返回平衡点的值(可能由多个); 若不存在返回 -1; ``java int [] arr = {2,3,4,2,4}; ```js const ar ...

    4. [LeetCode] 894. All Possible Full Binary Trees 所有可能的满二叉树

      A full binary tree is a binary tree where each node has exactly 0 or 2 children. Return a list of al ...

    5. UVA 712-S-Trees(满二叉树的简单查询)

      题意:给一棵满二叉树,叶子节点赋予权值,0或者1,对于每个查询输出叶子节点的权值,每个查询0代表往左走,1代表往右走,这题坑的地方是层的访问顺序,如第二组测试,由上到下依次是x3,x1,x2,假如给一 ...

    6. [Swift]LeetCode894. 所有可能的满二叉树 | All Possible Full Binary Trees

      A full binary tree is a binary tree where each node has exactly 0 or 2 children. Return a list of al ...

    7. 【C++】满二叉树问题

      /* 给出一棵满二叉树的先序遍历,有两种节点:字母节点(A-Z,无重复)和空节点(#).要求这个树的中序遍历.输出中序遍历时不需要输出#. 满二叉树的层数n满足1<=n<=5. Sampl ...

    8. python实现满二叉树递归循环

      一.二叉树介绍点这片文章 二叉树及题目介绍 例题: 有一颗满二叉树,每个节点是一个开关,初始全是关闭的,小球从顶点落下, 小球每次经过开关就会把它的状态置反,这个开关为关时,小球左跑,为开时右跑.现在 ...

    9. PAT甲级题解-1123. Is It a Complete AVL Tree (30)-AVL树+满二叉树

      博主欢迎转载,但请给出本文链接,我尊重你,你尊重我,谢谢~http://www.cnblogs.com/chenxiwenruo/p/6806292.html特别不喜欢那些随便转载别人的原创文章又不给 ...

    随机推荐

    1. Flume(一) —— 启动与基本使用

      基础架构 Flume is a distributed, reliable(可靠地), and available service for efficiently(高效地) collecting, a ...

    2. SpringBoot定时任务@Scheduled

      SpringBoot定时任务主要由两个注解完成. @Scheduled加在方法上面. @EnableScheduling加在类上面.可以是Application类,也可以是@Component类,还可 ...

    3. Vue 打包部署到服务器后,非主页刷新后出现404问题解决

      开心把项目部署到服务上,从头到尾点了一遍,发现没有问题,以为就可以大功告成,没想到刷新页面时出现 被破泼了一脸的凉水,更奇怪的事首页没有问题,只有其他页面出现,在调戏了很久的度娘后,才从坑里跳出来,以 ...

    4. SSM项目实战 之 EasyUI

      目录 EasyUI 简介 概述 使用EasyUI panel组件 简介 示例 JS形式及属性介绍 panel事件与方法 Window组件 概述 使用 行为 dialog 概述 使用 tabs组件 概述 ...

    5. DELPHI7 ADO二层升三层新增LINUX服务器方案

      DELPHI7 ADO二层升三层新增LINUX服务器方案 引子:笔者曾经无数次在用户的LINUX服务器上创建一个WINDOWS虚拟机,用于运行自己DELPHI开发中间件. 现在再不需要如此麻烦了. 咏 ...

    6. Typescript 开发环境的最佳实践

      Typescript 开发环境的最佳实践 0️⃣ git init(略) 1️⃣️️ 初始化:$ yarn add -D ts-node typescript 2️⃣ 生成 tsconfig.json ...

    7. Robotics Education and Research at Scale - A Remotely Accessible Robotics Development Platform

      张宁  Robotics Education and Research at Scale - A Remotely Accessible Robotics Development Platform链接 ...

    8. Qt编写图片及视频TCP/UDP网络传输

      一.前言 很多年前就做过类似的项目,无非就是将本地的图片上传到服务器,就这么简单,其实用http的post上传比较简单容易,无需自定义协议,直接设置好二进制数据即可,而采用TCP或者UDP通信的话,必 ...

    9. LeetCode_447. Number of Boomerangs

      447. Number of Boomerangs Easy Given n points in the plane that are all pairwise distinct, a "b ...

    10. 查看已安装dpkg包的poinst安装文件

      /var/lib/dpkg/info |grep printburn(软件名称) /var/lib/dpkg/info 文件都在这个目录下面poinst, preinst,prerm等