【数据结构】树与二叉树(一):树(森林)的基本概念:父亲、儿子、兄弟、后裔、祖先、度、叶子结点、分支结点、结点的层数、路径、路径长度、结点的深度、树的深度-CSDN博客

5.1 树的基本概念

5.1.1 树的定义

  • 一棵树是结点的有限集合T
    • 若T非空则
      • 有一个特别标出的结点称作该树的记为root(T)
      • 其余结点分成若干个不相交的非空集合T1, T2, …, Tm (m>0)其中T1, T2, …, Tm又都是树称作root(T)的子树
        • 在这里插入图片描述
    • T 空时为空树记作root(T)=NULL。

有序树、无序树

  如果子树T1, T2, …, Tm 的相对次序被指明则称该树为有序树否则称为无序树
  在有序树中把Ti (1≤i≤m)称作根的第 i 个子树。因为计算机表示定义了树的一种隐含次序所以大多数情况下假定所讨论的树都是有序的除非另有说明。

  • 如果是有序树那么两者是不同的如果是无序树那么两者是相同的。
    在这里插入图片描述

5.1.2 森林的定义

  一个森林是0棵或多棵不相交非空树的集合通常是一个有序的集合。换句话说森林由多个树组成这些树之间没有交集且可以按照一定的次序排列。在森林中每棵树都是独立的具有根节点和子树树与树之间没有直接的连接关系。
  森林是树的扩展概念它是由多个树组成的集合。在计算机科学中森林也被广泛应用于数据结构和算法设计中特别是在图论和网络分析等领域。

5.1.3 树的术语

1. 父亲parent、儿子child、兄弟sibling、后裔descendant、祖先ancestor

在这里插入图片描述

  • 这些术语用于描述节点之间的关系和层次结构

    • 每个节点都是它的子树的根节点的父亲
    • 反过来每个节点都是它父亲的儿子
    • 具有相同父亲的节点称为兄弟
    • 每个节点都是它子树中所有节点的祖先
    • 反过来每个节点都是它祖先的后裔
  • 节点之间的父子关系和兄弟关系可以帮助我们理解树的结构和遍历算法

  • 祖先和后裔的概念则用于描述节点之间的历史关系和衍生关系。

2. 度degree、叶子节点leaf node、分支节点internal node

在这里插入图片描述

  • 一个节点的儿子的个数称为该节点的次数
  • 如果一个节点的度为0则它被称为终端节点叶子节点在严格意义上非根的终端节点称为叶子节点
  • 非终端节点称为分支节点

  在图5.1中节点B有一个子树其度为1节点A有三个子树其度为3因此这棵树的度为3可以称为3元树3-ary tree。叶子节点是度为0的节点例如在图5.1中节点F、G、H和I是叶子节点而节点A、B、C、D和E是分支节点。

3. 结点的层数

  • 结点的层数是根据递归定义来确定的
    • 根节点的层数为0。
    • 其余节点的层数是其父节点的层数加1。
  • 根节点位于第0层它的子节点位于第1层子节点的子节点位于第2层依此类推。
    在这里插入图片描述

4. 路径、路径长度、结点的深度、树的深度

  • 路径是指结点序列v1, v2, …, vk其中每个节点vi是节点vi+1的父节点1 ≤ i < k。
  • 路径长度是指路径经过的边数即k-1。
  • 结点vi的深度是指从根节点到结点vi的路径长度 D e p t h ( i ) Depth(i) Depth(i)
  • 一棵树的深度是指树中所有节点深度的最大值 m a x i = 1 , … , n D e p t h ( i ) max_{i=1,…, n}Depth(i) maxi=1,,nDepth(i)

在这里插入图片描述
  图5.1的树中结点序列A, B, E是结点A到结点E的路径路经长度为2结点E的深度为2树的深度为3。

5.1.4 树的表示

1树形表示法

  树形表示法是一种图形化的表示方法使用节点和边来表示树的结构。每个节点代表树中的一个元素而边表示节点之间的关系。这种表示方法可以直观地展示树的层次结构和节点之间的连接关系。
  python创建树

class TreeNode:
    def __init__(self, value):
        self.value = value
        self.children = []

# 创建一个树
root = TreeNode('A')
node1 = TreeNode('B')
node2 = TreeNode('C')
node3 = TreeNode('D')

root.children.append(node1)
root.children.append(node2)
node2.children.append(node3)

2嵌套集合表示法

tree = {
    'value': 'A',
    'children': [
        {
            'value': 'B',
            'children': []
        },
        {
            'value': 'C',
            'children': [
                {
                    'value': 'D',
                    'children': []
                }
            ]
        }
    ]
}

3嵌套括号表示法

tree_str = '((A (B C)) D)'

4凹入表示法

def print_tree(node, level=0):
    if node is None:
        return
    print('  ' * level + str(node.value))
    for child in node.children:
        print_tree(child, level + 1)

print_tree(root)
阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

“【数据结构】树与二叉树(一):树(森林)的基本概念:父亲、儿子、兄弟、后裔、祖先、度、叶子结点、分支结点、结点的层数、路径、路径长度、结点的深度、树的深度-CSDN博客” 的相关文章