数据结构完全二叉树性质

数据结构完全二叉树性质完全二叉树若二叉树左子树高度-右子树高度小于等于1且大于等于0则称该二叉树为完全二叉树。二叉树一般性质:性质1:二叉树第i层上的结点数目最多为2i−1(i≥1)2^{i-1}(i\geq1)2i−1(i≥1)性质2:深度为k的二叉树至多有2k−1(k≥1)2^{k-1}(k\geq1)2k−1(k≥1)个结点性质3:包含n个结点的二叉树的高度至少为log⁡2n+1\log_2n+1log2​n+1性质4:在任意一棵二叉树中,若叶子结点的个数为n0n_0n0​,度为2的结点数为n2n_2n

大家好,又见面了,我是你们的朋友全栈君。

完全二叉树

若二叉树左子树高度-右子树高度小于等于1且大于等于0则称该二叉树为完全二叉树。
二叉树一般性质:
性质1:二叉树第i层上的结点数目最多为 2 i − 1 ( i ≥ 1 ) 2^{i-1}(i \geq 1) 2i1(i1)

性质2:深度为k的二叉树至多有 2 k − 1 ( k ≥ 1 ) 2^{k-1}(k \geq 1) 2k1(k1)个结点

性质3:包含n个结点的二叉树的高度至少为 log ⁡ 2 n + 1 \log_2n+1 log2n+1

性质4:在任意一棵二叉树中,若叶子结点的个数为 n 0 n_0 n0,度为2的结点数为 n 2 n_2 n2,则 n 0 = n 2 + 1 n_0=n_2+1 n0=n2+1
性质4推导:
易知结点总数 n = n 0 + n 1 + n 2 n=n_0+n_1+n_2 n=n0+n1+n2,根据二叉树的度之和(边数量)=n-1,可得 n − 1 = n 0 ∗ 0 + n 1 ∗ 1 + n 2 ∗ 2 n-1=n_0*0+n_1*1+n_2*2 n1=n00+n11+n22
联合上面两个公式即可得到性质4
完全二叉树性质:
性质1:度为1的结点仅有1个或0个(叶子节点尽可能往左排)
性质2:叶子结点个数 = n 2 =\frac{n}{2} =2n = n + 1 2 =\frac{n+1}{2} =2n+1(n为奇数)
利用 n = n 0 + n 1 + n 2 n=n_0+n_1+n_2 n=n0+n1+n2 n 0 = n 2 + 1 n_0=n_2+1 n0=n2+1与性质1容易证明。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/138250.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月31日 下午7:16
下一篇 2022年5月31日 下午7:16


相关推荐

  • 腾讯云 上传视频_云点播系统源码

    腾讯云 上传视频_云点播系统源码 web利用腾讯云点播上传视频到云服务器第一步导入<scriptsrc="//imgcache.qq.com/open/qcloud/js/vod/sdk/ugcUploader.js"></script>第二步在服务端设置秘钥,我用的是javaee编写一个Signature类 所需jar包http://download.csdn.net/down…

    2025年7月4日
    5
  • 2019版idea激活码99年(注册激活)

    (2019版idea激活码99年)最近有小伙伴私信我,问我这边有没有免费的intellijIdea的激活码,然后我将全栈君台教程分享给他了。激活成功之后他一直表示感谢,哈哈~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html2J…

    2022年3月29日
    504
  • BackTrack3(BT3激活成功教程wifi密码)

    BackTrack3(BT3激活成功教程wifi密码)BackTrack3(BT3激活成功教程)  准备工作  1、一个有可激活成功教程无线信号的环境。如我在家随便搜索出来的信号。  2、带无线网卡的电脑一台(笔记本台式机均可,只要无线网卡兼容BT3),我用的是三星NC10的上网本。  3、4G以上优盘一个(我用的是kingston8G的)  4、下载BT3,约900多兆。注:BT3全称BackTrack3,与我们常说的bt下载是完全不同的…

    2022年10月1日
    4
  • spring中@EventListener 的详解和使用

    spring中@EventListener 的详解和使用转载:面了个35的程序员,让我莫名的慌了。。。(欢迎关注原文作者公众号:Java充电社)面了个35的程序员,让我莫名的慌了。。。原创路人甲Java路人甲Java2020-05-10收录于话题#Spring高手系列55个内容月底免费送书活动,这两天是最后的机会,大家尽快参与!面试官:看你是85年的我:嗯,35了面试官:那应该经验很丰富了,那我们来聊聊spring吧我:好,这块我用了10几年了,你随便问吧面试官:Spring中的事件用过么?我:用过…

    2025年8月12日
    5
  • Java实现定时任务

    Java实现定时任务文章目录 1 使用 java util Timer2 使用 ScheduledExe 使用 SpringTask1 使用 java util Timer 这种方式的定时任务主要用到两个类 Timer 和 TimerTask 使用起来比较简单 其中 Timer 负责设定 TimerTask 的起始与间隔执行时间 TimerTask 是一个抽象类 new 的时候实现自己的 run 方法 然后将其丢给 Timer 去执行即可 代码示例 importjava time LocalDateTi

    2026年3月17日
    2
  • [redis] hashmap数据结构

    [redis] hashmap数据结构一、描述

    2022年5月12日
    67

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号