二叉树的定义及性质

在讨论一般树的存储结构及其操作之前,我们首先研究一种简单而极其重要的树结构 —— 二叉树。

二叉树的定义

二叉树(Binary Tree) 是另外一种树型结构,它的特点是每个节点至多只有两棵子树(即二叉树中不存在度大于2的结点),并且,二叉树的子树有左右之分,其次序不能任意颠倒。

与树的递归定义类似,二叉树的递归定义如下:二叉树或者是一棵空树,或者是一棵由一个根结点和两棵互不相交的分别称为根的左子树和右子树的子树所组成的非空树。

由以上定义可以看出,二叉树中每个结点的孩子数只能是0、1或2个,并且每个孩子都有左右之分。位于左边的孩子称为左孩子,位于右边的孩子称为右孩子;以左孩子为根的子树称为左子树,以右孩子为根的子树称为右子树。

二叉树的性质

二叉树具有下列重要特性:

性质1: 在二叉树的第i层上至多有2i-1个结点(i>=1)

利用归纳法,不难证明此性质,这里不再赘述。

性质2: 深度为k的二叉树至多有2k-1个结点,(k>=1).

证明:由性质1可得,深度为k的二叉树的最大结点数为:

这里写图片描述

性质3: 对任何一棵二叉树T,如果其终端结点数位n0,度为2的结点数为n2,则 n0 = n2 + 1

证明:

设n1为二叉树T中度为1的结点数,因为二叉树中所有结点的度均小于或等于2,所以其结点总数为:

n = n0 + n1 + n2

再看二叉树的分支数。除了根结点外,其余结点都有一个分支进入,设B为分支总数,则 n=B+1。由于这些分支是由度为1或2的结点射出的,所以又有 B=n1 + 2*n2。于是得:

n = n1 + 2*n2 + 1

由上述两个式子可得:

n0 = n2 + 1


满二叉树

一棵深度为k且有 2k-1 个结点的二叉树称为满二叉树。满二叉树的特点是,每一层上的结点数都是最大结点数。

完全二叉树

可以对满二叉树的结点进行连续编号,约定编号从根结点起,自上而下,自左至右。由此可以引出完全二叉树的定义。深度为k的,有n个结点的二叉树,当且仅当其每一个结点都与深度为k的满二叉树中编号从1至n的结点一一对应,称之为完全二叉树。

完全二叉树的特点是:(1)叶子结点只可能在层次最大的两层上出现;(2)对任一结点,若其右分支下的子孙的最大层次为l,则其左分支下的子孙的最大层次必为ll+1

如下图所示,(a)是一棵满二叉树,(b)是一棵完全二叉树。

这里写图片描述


完全二叉树将在很多场合下出现,下面介绍完全二叉树的两个重要特性.

性质4: 具有n个结点的完全二叉树的深度为 ⌊log2n⌋+1

证明:假设深度为k,则根据性质2和完全二叉树的定义有:

2k-1 - 1 < n <= 2k - 1 或 2k-1 <= n < 2k

于是有:

k-1 <= log2n < k,因为k是整数,所以 k = ⌊log2n⌋+1

性质5: 如果对一棵有n个结点的完全二叉树(其深度为 ⌊log2n⌋+1 )的结点按层序编号(从第1层到第 ⌊log2n⌋+1 层,每层从左到右),则对任一结点i(1<=i<=n),有:

(1)如果i=1,则结点i是二叉树的根,无双亲;如果i>1,则其双亲PARENT(i)是结点⌊i/2⌋。

(2)如果2i>n,则结点i无左孩子(结点i为叶子结点);否则其左孩子LCHILD(i)是结点2i。

(3)如果2i+1>n,则结点i无右孩子;否则其右孩子RCHILD(i)是结点2i+1。

### 二叉树定义 二叉树是一种特殊的树形数据结构,其特点是每个节点最多有两个子节点,并且这两个子节点通常被区分为左子节点和右子节点[^1]。具体来说,二叉树可以定义为 n (n ≥ 0) 个节点组成的有限集合。这个集合要么为空(即空二叉树),要么由一个根节点以及两棵互不相交的、分别被称为左子树和右子树的二叉树组成[^2]。 --- ### 二叉树性质 以下是关于二叉树的一些重要性质: #### 性质 1 在任意一棵二叉树中,如果第 i 层有节点,则该层上的最大节点数为 \(2^{i-1}\),其中 i ≥ 1[^3]。 #### 性质 2 对于高度为 h 的二叉树,其最大节点总数为 \(2^h - 1\),这里假设树的高度从 1 开始计算[^3]。 #### 性质 3 对于任何一颗非空二叉树,若叶子节点的数量为 \(n_0\),而度为 2 的节点数量为 \(n_2\),则满足关系式:\(n_0 = n_2 + 1\)[^2]。 #### 性质 4 具有 n 个节点的完全二叉树的高度 h 满足 \(\lceil{\log_2{(n+1)}}\rceil - 1 ≤ h ≤ n\)[^3]。 #### 特殊类型的二叉树及其性质 1. **满二叉树** 如果一棵二叉树除了最后一层外的所有其他层都填满了节点,并且所有的叶节点都在同一层上,则这是一颗满二叉树[^3]。它的总节点数可以用公式 \(2^h - 1\) 表示,其中 h 是树的高度。 2. **完全二叉树** 若除可能的最后一层之外,其余各层都被完全填充;并且最后一层的节点均集中在最左侧位置,则此树为完全二叉树[^3]。这种形式的二叉树非常适合采用数组进行顺序存储实现。 --- ### 示例代码展示 下面是一个简单的 Python 实现用于创建并打印二叉树节点数目: ```python class TreeNode: def __init__(self, value=0, left=None, right=None): self.value = value self.left = left self.right = right def count_nodes(root: TreeNode) -> int: if root is None: return 0 return 1 + count_nodes(root.left) + count_nodes(root.right) # 构建简单二叉树实例 root = TreeNode(1) root.left = TreeNode(2) root.right = TreeNode(3) root.left.left = TreeNode(4) print(f"Total nodes in the binary tree: {count_nodes(root)}") # 输出应为 4 ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值