二叉树的定义

二叉树(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. 微信小程序之页面导航栏

      效果图: 页面有点丑,作为初次学习,页面可以要求不那么美观,先学会再说.毕竟后面可以优化的很漂亮. 代码实例如下: <view class="section btn-area" ...

    2. SDN-based Network Management Solution

      SDN-based Network Management Solution 摘要: 在此项目中,我们开发了一种网络管理应用程序,以监视和控制由支持OpenFlow的交换机和支持SNMP的设备组成的企业 ...

    3. 使用lombok的@Builder的注解的一个坑

      一开发说项目报错 java.lang.Long,java.lang.String,java.lang.String,java.lang.String,java.lang.String,java.lan ...

    4. C# 获取文件扩展信息-应用名称/作者等

      方案一:使用微乳封装的Shell包 添加nuget包:Microsoft.WindowsAPICodePack.Shell using Microsoft.WindowsAPICodePack.She ...

    5. Leetcode: Find And Replace in String

      To some string S, we will perform some replacement operations that replace groups of letters with ne ...

    6. python之psutil模块

      简述 psutil是一个跨平台库(http://code.google.com/p/psutil/) ,能够轻松实现获取系统运行的进程和系统利用率(包括CPU.内存.磁盘.网络等)信息.它主要应用于系 ...

    7. android基础---->WebView的使用

      webView的使用 我们通过一个小的测试程序来体会webView的简单使用,项目结构如下:

    8. PHP阿里大于发短信教程

      PHP阿里大于发短信教程 1 先去控制台 https://www.alidayu.com/center/user/account?spm=a3142.7791109.1999204004.5.ZtBQ ...

    9. LeetCode 103. 二叉树的锯齿形层次遍历(Binary Tree Zigzag Level Order Traversal)

      103. 二叉树的锯齿形层次遍历 103. Binary Tree Zigzag Level Order Traversal 题目描述 给定一个二叉树,返回其节点值的锯齿形层次遍历.(即先从左往右,再 ...

    10. Apache Kafka主题 - 架构和分区

      1.卡夫卡话题 在这篇Kafka文章中,我们将学习Kafka主题与Kafka Architecture的整体概念.Kafka中的体系结构包括复制,故障转移以及并行处理.此外,我们还将看到创建Kafka ...