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

图一
节点、度和叶子的概念
二叉树中的每一个元素都称为结点。通常二叉树的许多名词借用了家族关系
例如在上图中,2、3均是1的子结点,1是2&3的双亲,因而2、3互为“兄弟结点”
二叉树的度代表某个结点的孩子或者后继人的个数,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.同样结点数的二叉树,完全二叉树的深度最小
二叉树&满二叉树与完全二叉树的更多相关文章
- 树&二叉树&&满二叉树&&完全二叉树&&完满二叉树
		
目录 树 二叉树 完美二叉树(又名满二叉树)(Perfect Binary Tree) 完全二叉树(Complete Binary Tree) 完满二叉树(Full Binary Tree) 树 名称 ...
 - 【algo&ds】【吐血整理】4.树和二叉树、完全二叉树、满二叉树、二叉查找树、平衡二叉树、堆、哈夫曼树、B树、字典树、红黑树、跳表、散列表
		
本博客内容耗时4天整理,如果需要转载,请注明出处,谢谢. 1.树 1.1树的定义 在计算机科学中,树(英语:tree)是一种抽象数据类型(ADT)或是实作这种抽象数据类型的数据结构,用来模拟具有树状结 ...
 - 找出 int 数组的平衡点 & 二叉树 / 平衡二叉树 / 满二叉树 / 完全二叉树 / 二叉查找树
		
找出 int 数组的平衡点 左右两边和相等, 若存在返回平衡点的值(可能由多个); 若不存在返回 -1; ``java int [] arr = {2,3,4,2,4}; ```js const ar ...
 - [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 ...
 - UVA 712-S-Trees(满二叉树的简单查询)
		
题意:给一棵满二叉树,叶子节点赋予权值,0或者1,对于每个查询输出叶子节点的权值,每个查询0代表往左走,1代表往右走,这题坑的地方是层的访问顺序,如第二组测试,由上到下依次是x3,x1,x2,假如给一 ...
 - [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 ...
 - 【C++】满二叉树问题
		
/* 给出一棵满二叉树的先序遍历,有两种节点:字母节点(A-Z,无重复)和空节点(#).要求这个树的中序遍历.输出中序遍历时不需要输出#. 满二叉树的层数n满足1<=n<=5. Sampl ...
 - python实现满二叉树递归循环
		
一.二叉树介绍点这片文章 二叉树及题目介绍 例题: 有一颗满二叉树,每个节点是一个开关,初始全是关闭的,小球从顶点落下, 小球每次经过开关就会把它的状态置反,这个开关为关时,小球左跑,为开时右跑.现在 ...
 - PAT甲级题解-1123. Is It a Complete AVL Tree (30)-AVL树+满二叉树
		
博主欢迎转载,但请给出本文链接,我尊重你,你尊重我,谢谢~http://www.cnblogs.com/chenxiwenruo/p/6806292.html特别不喜欢那些随便转载别人的原创文章又不给 ...
 
随机推荐
- 2019暑假Java学习笔记(二)
			
目录 基础语法(下) 流程控制 if语句 switch语句 while语句和do-while语句 for语句 break关键字 continue关键字 数组 一维数组 二维数组 用户输入操作 练习题: ...
 - Java实现Txt转PDF文件
			
TxT转PDF可以直接使用IText就可以了,IText在pdf领域可以说暂时是最好的方案了.通过直接读取txt文件,然后生成pdf,再添加文本就可以了. 代码如下: public class Txt ...
 - UltraEdit 的“查看方式”着色类项型
			
UltraEdit 的“查看方式”着色类项型 2011年06月22日 13:16:00 cnki_ok 阅读数 5722 版权声明:本文为博主原创文章,遵循CC 4.0 by-sa版权协议,转载请 ...
 - Cucumber介绍
			
Cucumber是一个提供能让我们都理解的普通语言,通过普通语言来描述的测试用例,并支持行为驱动开发的测试工具.Cucumber支持大多数变成语言,如Ruby.Java和Python等. 官方地址:h ...
 - 深入理解Flink ---- 系统内部消息传递的exactly once语义
			
At Most once,At Least once和Exactly once 在分布式系统中,组成系统的各个计算机是独立的.这些计算机有可能fail. 一个sender发送一条message到rec ...
 - html网页调用本地exe程序的实现方法(转)
			
https://blog.csdn.net/ilovecr7/article/details/46803711 最近在做一个项目,要什么网页里调exe...开始以为不能实现,后来想想很多就跟淘宝网页上 ...
 - [LeetCode] 330. Patching Array 数组补丁
			
Given a sorted positive integer array nums and an integer n, add/patch elements to the array such th ...
 - [LeetCode] 454. 4Sum II 四数之和II
			
Given four lists A, B, C, D of integer values, compute how many tuples (i, j, k, l) there are such t ...
 - IFC文件介绍
			
IFC是一个数据交换标准, 用于不同系统交换和共享数据. IFC是采用EXPRESS语言定义的实体关系模型,由几百个实体对象组成.实体对象包括建筑要素如IfcWall,几何元素如IfcExtruded ...
 - 高级UI-自定义控件
			
自定义控件在Android开发中有着大量的运用,为了做出符合项目的效果很多时候需要自定义控件,这里就使用两个自定义控件,来说明自定义控件的使用流程 仿QQ侧滑 之前使用DrawerLayout和Nav ...