[数据结构]-12二叉树

二叉树

n ( n ≥ 0 ) n(n\ge 0) n(n0) 个结点组成的有限集,每一个根结点最多有两棵互不相交的子树,这样的树称为二叉树。
n = 0 n = 0 n=0 时称为空树;二叉树中有且只有一个称为根的结点。
除根结点以外的其余结点分为两个互不相交的子集 T 1 T1 T1 T 2 T2 T2 T 1 T1 T1 称为根的左子树, T 2 T2 T2 称为根的右子树, T 1 T1 T1 T 2 T2 T2 又可以看作二叉树。

二叉树的特点:结点的子树有左右之分,其次序不能颠倒;二叉树的度不超过 2。二叉树可以是空集,根也可以有空的左子树或空的右子树。

二叉树不是树的特殊情况:二叉树每个结点最多有两棵子树,而树结点的子树可以有无数棵;二叉树结点的子树要区分左子树或右子树,次序不能任意颠倒;树结点只有一个孩子时,没有左右次序之分。

二叉树的性质:

  • 在二叉树的第i层上最多有 2 i − 1 2^{i-1} 2i1 个结点,最少有 1 个结点。
  • 深度为 k k k 的二叉树最多有 2 i − 1 2^i-1 2i1 个结点( k ≥ 1 k\ge 1 k1 )。
  • 对任何一棵二叉树 T T T,如果其叶子数为 n 0 n_0 n0,度为 2 的结点数为 n 2 n_2 n2 个,则 n 0 = n 2 + 1 n_0 = n_2 + 1 n0=n2+1
    证明如下:
  1. 二叉树结点总数: n = n 0 + n 1 + n 2 n = n_0 + n_1 + n_2 n=n0+n1+n2
  2. 除了根结点外,其余结点都有一个分支进入,设 B B B 为分支总数,则 n = B + 1 n = B + 1 n=B+1
  3. 由于树的分支是由度为 1 或 2 的结点射出,所以 B = n 1 + 2 ∗ n 2 B = n_1 + 2 * n_2 B=n1+2n2
  4. 综上所述: n = n 1 + 2 ∗ n 2 + 1 ⇒ n 0 = n 2 + 1 {n = n_1 + 2 * n_2 + 1} \Rightarrow n_0 = n_2&#
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!
提供的源码资源涵盖了小程序应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值