数据结构之满二叉树和完全二叉树的区别

本文介绍了满二叉树和完全二叉树的概念、性质及其区别。满二叉树是一种节点数量固定的二叉树,便于使用顺序结构存储,而完全二叉树是节点数量任意,但最后一层节点都是靠左排列,两者在实际应用中有不同的适用场景。
摘要由CSDN通过智能技术生成
二叉树分类很多,其中满二叉树和完全二叉树比较特殊,因为这两种二叉树效率很高,这里记录几条相关性质。
 
首先是满二叉树:从形象上来说满二叉树是一个绝对的三角形,也就是说它的最后一层全部是叶子节点,其余各层全部是非叶子节点,如果用数学公式表示那么其节点数n=2^k-1其中k表示深度,也就是层数。也就是说满二叉树的节点数是一系列固定的数,比如说,1,3,7,15...如果节点数不是这个序列中的数,那么他肯定不是满二叉树,当然了,反之,也是成立的。
 
由于它的节点数和形状固定,我们可以发现很多其数学公式性质。
 
首先是节点数和深度的关系 n=2^k-1
 
第二是第i层上的节点数为2^(i-1)
 
第三是给所有的节点编号(从1号开始而不是从零号开始),对于一个编号为i的节点我们可以根据i的大小,判断出他是左节点还是右节点,父节点是谁,子节点是谁。比如我们给一个编号13的节点,那么他是奇数所以他是右节点,因为节点的左右变化和数据的奇偶性是同步变化的。他的父节点是13/2=6(是从1号开始的)他的左子节点是13*2=26右子节点是13*2+1=27同理还可以求他的兄弟节点,父节点的父节点,
 
总而言之在满二叉树中只要有了一个节点的编号那么他在整个二叉树中的位置就确定了,正是由于这个原因,我们更倾向于使用顺序结构而不是链式
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AI绘画(可定制)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值