数据结构-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


三.总结:


相关推荐
潇潇云起4 小时前
mapdb
java·开发语言·数据结构·db
咚咚王者4 小时前
人工智能之核心基础 机器学习 第十章 降维算法
人工智能·算法·机器学习
源代码•宸4 小时前
Golang语法进阶(Context)
开发语言·后端·算法·golang·context·withvalue·withcancel
源代码•宸4 小时前
Golang语法进阶(Sync、Select)
开发语言·经验分享·后端·算法·golang·select·pool
sali-tec4 小时前
C# 基于OpenCv的视觉工作流-章8-形态学
人工智能·深度学习·opencv·算法·计算机视觉
栈与堆4 小时前
数据结构篇(1) - 5000字细嗦什么是数组!!!
java·开发语言·数据结构·python·算法·leetcode·柔性数组
LightYoungLee4 小时前
算法(五)树 Trees V2
学习·算法·深度优先
enmouhuadou5 小时前
什么是I/Q信号?
算法·信息与通信
2301_800256116 小时前
第九章:空间网络模型(空间网络查询、数据模型、Connected、with Recursive、pgRouting)
网络·数据库·算法·postgresql·oracle
逑之7 小时前
C语言笔记10:sizeof和strlen,指针与数组
c语言·笔记·算法