数据结构-5.4.二叉树的性质

一.二叉树的常考性质:

常见考点1:结点个数的性质

设非空二叉树(度最大为2,最小为0)当中度为0的结点个数为a,度为1的结点个数为b,度为2的结点个数为c,那么a=b+c:

推导过程:设该非空二叉树共有n个结点,那么n=a+b+c,

由树的结点数=总度数+1,n = ( 0 * a + 1 * b + 2 * c ) + 1 = b+2c+1

所以a = c +1

常见考点2:树的每层中的结点个数范围

常见考点3:树中结点最多可以有多少个


二.完全二叉树的常考性质:

常见考点1:已知结点个数,求完全二叉树的高度

法一:

上述图片中高度为h的完全二叉树的结点有n个,完全二叉树可由满二叉树推出来,

高度为h的满二叉树的结点有2的h的幂减1个,

高度为h-1的满二叉树的结点有2的(h-1)的幂减1个,

由于该完全二叉树的高度为h,所以它的结点数是一定大于高度为h-1的满二叉树的结点数,不能取等,取等的话完全二叉树的高度就只能是h-1,因为高度为h-1的满二叉树的结点已经满了,要想等于该h-1的满二叉树的结点数,该完全二叉树的高度只能为h-1,由于完全二叉树可由满二叉树推出来,所以高度为h的完全二叉树的结点数是小于或等于高度为h的满二叉树的结点数,可以取等,因为满二叉树是特殊的完全二叉树且高度都为h。

(上述图片里是向上取整得出h的结果)

法二:

思路:首先要保证完全二叉树的高度为h,那么第h-1层就一定排满了(因为完全二叉树最多只能有一个度为1的结点,达到完全二叉树的结点最少时且高度为h,那么就只能在第h层放一个结点,此时第h-1层就必须排满,如果把这一个结点放到第h层以外,编号就会与满二叉树不符),再多一个就能排到第h层了,其次,当h层全部排满时,就不能再添加结点了,否则就排到第h+1层了

(上述图片里是向下取整得出h的结果)

常见考点2:对于完全二叉树,可以由总结点数n推出度分别为0,1,2的结点个数为a,b,c

推导过程:在完全二叉树中,n=a+b+c,

由树的结点数=总度数+1,n = ( 0 * a + 1 * b + 2 * c ) + 1 = b+2c+1

所以a = c +1 -> a+c = 2c+1 ,所以度为0的结点(叶子结点)总数和度为2的结点总数的和为奇数

完全二叉树最多只能有一个度为1的结点,所以b只能为1(奇数 )或者0(偶数)

因此,如果设n=2k为偶数,那么b只能为1,a为k,那么c为k-1

如果设n=2k-1为奇数,那么b只能为0,a为k,那么c为k-1


三.总结:


相关推荐
To_OC16 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户9385156350721 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC1 天前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥1 天前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者1 天前
Transformer模型部署之性能优化指南
算法
地平线开发者1 天前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月1 天前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星1 天前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星1 天前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试