当前位置:网站首页>013-Binary tree
013-Binary tree
2022-08-03 09:04:00 【51CTO】
二叉树的介绍
1. 二叉树的定义
二叉树是每个节点最多有两个子树的树结构.它有五种基本形态:二叉树可以是空集;根可以有空的左子树或右子树;或者左、右子树皆为空.
2. 二叉树的性质.
二叉树有以下几个性质:
性质1):The inequality relation between the level and the number of nodes on the level.Set up a binary treei层的节点数为f(i),则有:
f(i) <= 2(i - 1).(其中i >= 1).
性质2):二叉树的高度hwith the total number of binary tree nodesf(h)the inequality relation.Set the height of the binary treeh,二叉树的节点总数为f(h),则有:
f(h) <= 2h - 1.(其中h >= 1).
性质3):二叉树中度为2的个数为xwith the number of leaf nodesf(x)equation relationship.设二叉树中度为2的个数为x,The number of page nodes is f(x)则有:
f(x) = x + 1.(其中x >= 1).
2.1 性质1:二叉树第i层上的结点数目最多为 2{i-1} (i≥1)
证明:下面用"数学归纳法"进行证明.
(01) 当i=1时,第i层的节点数目为2{i-1}=2{0}=1.因为第1层上只有一个根结点,所以命题成立.
(02) 假设当i>1,第i层的节点数目为2{i-1}.这个是根据(01)推断出来的!
下面根据这个假设,推断出"第(i+1)层的节点数目为2{i}"即可.
由于二叉树的每个结点至多有两个孩子,故"第(i+1)层上的结点数目" 最多是 "第i层的结点数目的2倍".即,第(i+1)层上的结点数目最大值=2×2{i-1}=2{i}.
故假设成立,原命题得证!
2.2 性质2:深度为k的二叉树至多有2{k}-1个结点(k≥1)
证明:在具有相同深度的二叉树中,当每一层都含有最大结点数时,其树中结点数最多.利用"性质1"可知,深度为k的二叉树的结点数至多为:
20+21+…+2k-1=2k-1
故原命题得证!
2.3 性质3:包含n个结点的二叉树的高度至少为log2 (n+1)
证明:根据"性质2"可知,高度为h的二叉树最多有2{h}–1个结点.反之,对于包含n个节点的二叉树的高度至少为log2(n+1).
2.4 性质4:在任意一棵二叉树中,若终端结点的个数为n0,度为2的结点数为n2,则n0=n2+1
证明:因为二叉树中所有结点的度数均不大于2,所以结点总数(记为n)="0度结点数(n0)" + "1度结点数(n1)" + "2度结点数(n2)".由此,得到等式一.
(等式一) n=n0+n1+n2
另一方面,0度结点没有孩子,1度结点有一个孩子,2度结点有两个孩子,故二叉树中孩子结点总数是:n1+2n2.此外,只有根不是任何结点的孩子.故二叉树中的结点总数又可表示为等式二.
(等式二) n=n1+2n2+1
由(等式一)和(等式二)计算得到:n0=n2+1.原命题得证!
3. 满二叉树,完全二叉树和二叉查找树
3.1 满二叉树
定义:高度为h,并且由2{h} –1个结点的二叉树,被称为满二叉树.
3.2 完全二叉树
定义:一棵二叉树中,只有最下面两层结点的度可以小于2,并且最下一层的叶结点集中在靠左的若干位置上.这样的二叉树称为完全二叉树.
特点:叶子结点只能出现在最下层和次下层,且最下层的叶子结点集中在树的左部.显然,一棵满二叉树必定是一棵完全二叉树,而完全二叉树未必是满二叉树.
3.3 二叉查找树
定义:二叉查找树(Binary Search Tree),又被称为二叉搜索树.设x为二叉查找树中的一个结点,x节点包含关键字key,节点x的key值记为key[x].如果y是x的左子树中的一个结点,则key[y] <= key[x];如果y是x的右子树的一个结点,则key[y] >= key[x].
在二叉查找树中:
(01) 若任意节点的左子树不空,则左子树上所有结点的值均小于它的根结点的值;
(02) 任意节点的右子树不空,则右子树上所有结点的值均大于它的根结点的值;
(03) 任意节点的左、右子树也分别为二叉查找树.
(04) 没有键值相等的节点(no duplicate nodes).
在实际应用中,二叉查找树的使用比较多.
4、二叉树遍历问题.
(1)先序遍历.(确定根节点)
Visit the root of the tree first,Then visit the left subtree of this tree,Then visit the right subtree of this tree,Finally recursively visit the left and right subtrees.
举例说明.如下图:
According to the preorder traversal rules.The root of this tree is7,So preorder traversal is7,7Recursive preorder traversal of the left subtree of ,7Recursive preorder traversal of the right subtree of .
So the result of preorder traversal is :7,4,2,1,3,6,5,9,8,10
##############################################################
先序遍历:按照根节点->左子树->Sequential access to the right subtree of a binary tree
先序遍历:(1)访问根节点;(2)采用先序递归遍历左子树;(3)采用先序递归遍历右子树;
(注:每个节点的分支都遵循上述的访问顺序,体现“递归调用”)
先序遍历结果:A BDFE CGHI
思维过程:
(1)先访问根节点A,
(2)A分为左右两个子树,因为是递归调用,所以左子树也遵循“先根节点-再左-再右”的顺序,所以访问B节点,
(3)然后访问D节点,
(4)访问F节点的时候有分支,同样遵循“先根节点-再左--再右”的顺序,
(5)访问E节点,此时左边的大的子树已经访问完毕,
(6)然后遵循最后访问右子树的顺序,访问右边大的子树,右边大子树同样先访问根节点C,
(7)访问左子树G,
(8)因为G的左子树没有,所以接下俩访问G的右子树H,
(9)最后访问C的右子树I
(2)中序遍历.(knowing the root node,The left and right subtrees of the root node can be determined)
Visit the left subtree of this tree first,Then visit the root of this tree,Then visit the right subtree of this tree,Finally recursively visit the left and right subtrees.
举例说明.如下图:
根据中序遍历规则.The root of this tree is7,So inorder traversal is7Recursive inorder traversal of the left subtree of ,7,7Recursive inorder traversal of the right subtree of .
So the result of preorder traversal is :1,2,3,4,5,6,7,8,9,10
#############################################################
中序遍历:按照左子树->根节点->右子树的顺序访问
中序遍历:(1)采用中序遍历左子树;(2)访问根节点;(3)采用中序遍历右子树
中序遍历结果:DBEF A GHCI
(3)后序遍历.(确定根节点)
Visit the left subtree of this tree first,Then visit the right subtree of this tree,Visit the root of the tree again,Finally recursively visit the left and right subtrees.
举例说明.如下图:
According to the post-order traversal rules.The root of this tree is7,So postorder traversal is:7Recursive postorder traversal of the left subtree of ,7Recursive postorder traversal of the right subtree of ,7.
So the result of the postorder traversal is :1,3,2,5,6,4,8,10,9,7
###################################################
后序遍历
后序遍历:(1)采用后序递归遍历左子树;(2)采用后序递归遍历右子树;(3)访问根节点;
后序遍历的结果:DEFB HGIC A
(4)层次遍历.
从根节点开始,Traverse down layer by layer.
(5)Known pre-order traversal and in-order traversal to find post-order traversal,That is, determine the binary tree.
举例分析.先序遍历是:GDAFEMHZ.中序遍历是:ADEFGHMZ.求二叉树.
思路如下:(Determine the root first,Then determine the left subtree of the root,Then determine the right subtree of the root,然后递归左子树,然后递归右子树)
a、 根据先序遍历的特点——根左右,第一个元素一定是根节点,So be sure nowG是根节点.
b、 既然确定了G是根节点,Then according to the characteristics of in-order traversal——左根右,在根节点G之前的ADEF就是左子树,根节点G之后的HMZ就是右子树.
c、Then analyze the left subtree(思路和第1,2步一样).Put all elements of the left subtree(即ADEF这四个元素)The order in preorder traversal and inorder traversal is taken out for comparison.
d、The order of precedence isDAFE(中左右),中序遍历是ADEF(左中右).
e、It is derived from the pre-order featureD是左子树的节点,The only one is determined by the midorder featureD左边的Ais the left leaf in the left subtree,右边的是EF.
f、观察EF的相对位置,在先序(中左右)是FE,在中序(左中右)EF,所以得出EFThe relationship is left middle.
g、Then analyze the right subtree(思路和第1,2步一样),Put the elements of the right subtree(HMZ)The order in preorder traversal and inorder traversal is taken out for comparison.
h、The order of precedence isMHZ(中左右),中序遍历是HMZ(左中右).
i、Determined according to the characteristics of preorder traversalM是右子树的节点,Determined according to the characteristics of in-order traversalHis the left lobe,Zis the right lobe.
最后结果如下:那么后序遍历就是AEFDHZMG
(6)Post-order traversal and in-order traversal are known for pre-order traversal,That is, determine the binary tree.
(7)Inorder traversal cannot be determined based on preorder traversal and postorder traversal,That is, it cannot be determined to be a unique binary tree.
举例说明:
边栏推荐
猜你喜欢
随机推荐
LeetCode 每日一题——622. 设计循环队列
内存模型之有序性
手把手教你如何自制目标检测框架(从理论到实现)
greenplum role /user 管理
【论文笔记】基于动作空间划分的MAXQ自动分层方法
Redis cluster concept and construction
【LeetCode】112. Path sum
多媒体数据处理实验1:算术编码
10分钟带你入门chrome(谷歌)浏览器插件开发
HCIP练习(OSPF)
Redis集群概念与搭建
行业洞察 | 如何更好的实现与虚拟人的互动体验?
dflow入门2——Slices
国内IT市场还有发展吗?有哪些创新好用的IT运维工具可以推荐?
【LeetCode】老虎证券面试-括号嵌套且满足优先级
验证浮点数输入
QImage的指针问题
AcWing 3391. 今年的第几天?(简单题)
多媒体数据处理实验4:LSH索引
110道 MySQL面试题及答案 (持续更新)