计算二叉树中最后一层的叶子节点的个数:层序遍历

计算二叉树中距离根节点最远的叶子节点的个数,即二叉树中最后一层的叶子节点的个数。

如在下面的二叉树中,叶子节点的总数量为 4(分为3、4、6、8),最后一层的叶子节点的个数为 1(编号8):

     1
   /   \
  2     3
 / \
4   5
   / \
  6   7
       \
        8

方法:层序遍历

code:

from collections import deque


class Node:
    def __init__(self, value, left=None, right=None):
        self.value = value
        self.left = left
        self.right = right


# 计算二叉树中最后一层的叶子节点的个数
def leafNodeNum(root):
    if not root:
        return 0
    num = 0
    stack = deque()
    stack.append(root)

    # 层序遍历
    while stack:
        # 当前层级的叶子节点个数
        cur_num = 0

        length = len(stack)
        for _ in range(length):
            # 必须使用 popleft() 保证先进先出,不能使用 pop()
            # 使用 length 保证将上一层的节点全部弹出,而不弹出当前层级新加入的节点
            cur_node = stack.popleft()

            # 判断当前节点是否为叶子节点
            if not cur_node.left and not cur_node.right:
                cur_num += 1
            if cur_node.left:
                stack.append(cur_node.left)
            if cur_node.right:
                stack.append(cur_node.right)

        # 更新最大叶子节点个数
        num = max(num, cur_num)
    return num


if __name__ == '__main__':
    # 构建二叉树
    root = Node(1)
    root.left = Node(2)
    root.right = Node(3)
    root.left.left = Node(4)
    root.left.right = Node(5)
    root.left.right.left = Node(6)
    root.left.right.right = Node(7)
    root.left.right.right.left = Node(8)

    # 计算二叉树距离根节点最远的叶子节点个数
    max_leaves_count = leafNodeNum(root)
    print("二叉树中最后一层的叶子节点的数量为:", max_leaves_count)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ctrl A_ctrl C_ctrl V

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值