码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 5.【树的概念和基本术语】 +【树的常考性质】


    文章目录

    • 一. 树的定义和基本术语
    • 二. 树的常考性质
      • 1. 结点数 = 总度数 + 1
      • 2. 度为 m 的树、m 叉树的区别
      • 3. 度为 m 的树第 i 层至多有 m^i-1^个结点(i≥1)
      • 4. 高度为 h、度为 m 的树至多有 m h − 1 m − 1 \frac{m^h-1}{m-1} m−1mh−1​ 个结点。(等比数列求和)
      • 5. 高度为 h、度为 m 的树至少有(h+m-1)个结点。
      • 6. 具有 n 个结点的 m 叉树的最小高度为 ⌈log~m~ ( n ( m − 1 ) + 1 )⌉

    一. 树的定义和基本术语

    1. 树是n(n≥0)个结点的有限集合,n = 0时,称为 空树 。

      在这里插入图片描述

    2. 非空树中应满足:
      有且仅有一个特定的称为根的结点。
      当n > 1时,其余结点可分为m(m>0)个互不相交的有限集合T1,T2,…,Tm,其中每个集合本身又是一棵树,并且称为根结点的子树。

      在这里插入图片描述

    3. 度:树中一个结点的孩子个数称为该结点的度。所有结点的度的最大值是树的度。
      度大于0的结点称为分支结点,度为0的结点称为叶子结点。

    4. 结点的层次(深度):从上往下数。
      结点的高度:从下往上数。
      树的高度(深度):树中结点的层数。

    5. 祖先结点:从一个结点出发,一直向上走,一直走到根结点为止,所经过的所有结点都是祖先结点。
      子孙结点:从一个结点出发所有的分支都属于子孙结点。
      双亲结点(父结点):一个结点的直接前驱结点。
      孩子结点:一个结点的直接后继结点。
      兄弟结点:前驱结点为同一个结点的结点。

    6. 若树中结点的各子树从左至右是有次序的,不能互换,则该树称为有序树,否则称为无序树。

    7. 树中两个结点之间的路径是由这两个结点之间所经过的结点序列构成的,而路径长度是路径上所经过的边的个数。

    8. 森林:森林是m(m≥0)棵互不相交的树的集合。

      在这里插入图片描述



    二. 树的常考性质

    1. 结点数 = 总度数 + 1

    由于树的特殊结构以及度数的定义,我们可以发现第n-1层的结点度数之和就是第n层的所有结点数量,如此循环往复,我们就能知道从第1层到第n层的结点度数和实际上就是除了根节点之外的所有结点的数量。



    2. 度为 m 的树、m 叉树的区别

    度为m的树m叉树的区别
    任意结点的度≤m(最多m个孩子)任意结点的度≤m(最多m个孩子)
    至少有一个结点度=m(有m个孩子)允许所有结点的度都<m
    一定是非空树,至少有m+1个结点可以是空树



    3. 度为 m 的树第 i 层至多有 mi-1个结点(i≥1)

    同理:m 叉树第 i 层至多有 mi-1 个结点(i≥1)。

    image-20210911101519523



    4. 高度为 h、度为 m 的树至多有 m h − 1 m − 1 \frac{m^h-1}{m-1} m−1mh−1​ 个结点。(等比数列求和)

    等比数列求和公式:在这里插入图片描述      直接带入公式得到结果。



    5. 高度为 h、度为 m 的树至少有(h+m-1)个结点。

    高度为 h 的 m 叉树至少有 h 个结点
    在这里插入图片描述



    6. 具有 n 个结点的 m 叉树的最小高度为 ⌈logm ( n ( m − 1 ) + 1 )⌉

    在这里插入图片描述

  • 相关阅读:
    CAS :80750-24-9(脱硫生物素 NHS 酯)
    vue开启splitChunks分包处理
    如何看待unity新的收费模式
    js 对象循环遍历
    【广州华锐互动】VR防溺水安全内容体验提高群众防溺水意识
    Java-Web-Servlet入门2.0
    Web Worker 学习及使用
    念一句咒语 AI 就帮我写一个应用,我人麻了...
    涵盖Java核心知识的综合指南:JavaGuide | 开源日报 0912
    个人述职报告
  • 原文地址:https://blog.csdn.net/weixin_42214698/article/details/126260658
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号