已解决
计算二叉树中最后一层的叶子节点的个数:层序遍历
来自网友在路上 183883提问 提问时间:2023-09-23 03:54:10阅读次数: 83
最佳答案 问答题库838位专家为你答疑解惑
计算二叉树中距离根节点最远的叶子节点的个数,即二叉树中最后一层的叶子节点的个数。
如在下面的二叉树中,叶子节点的总数量为 4(分为3、4、6、8),最后一层的叶子节点的个数为 1(编号8):
1/ \2 3/ \
4 5/ \6 7\8
方法:层序遍历
code:
from collections import dequeclass Node:def __init__(self, value, left=None, right=None):self.value = valueself.left = leftself.right = right# 计算二叉树中最后一层的叶子节点的个数
def leafNodeNum(root):if not root:return 0num = 0stack = deque()stack.append(root)# 层序遍历while stack:# 当前层级的叶子节点个数cur_num = 0length = 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 += 1if cur_node.left:stack.append(cur_node.left)if cur_node.right:stack.append(cur_node.right)# 更新最大叶子节点个数num = max(num, cur_num)return numif __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)
查看全文
99%的人还看了
相似问题
- 〖大前端 - 基础入门三大核心之JS篇㊲〗- DOM改变元素节点的css样式、HTML属性
- Java 算法篇-链表的经典算法:判断回文链表、判断环链表与寻找环入口节点(“龟兔赛跑“算法实现)
- 代码随想录二刷 | 链表 | 删除链表的倒数第N个节点
- 节点导纳矩阵
- bhosts 显示节点 “unreach“ 状态
- 电子电器架构 —— 车载网关边缘节点总线转换
- 〖大前端 - 基础入门三大核心之JS篇㊳〗- DOM访问元素节点
- 第四天||24. 两两交换链表中的节点 ● 19.删除链表的倒数第N个节点 ● 面试题 02.07. 链表相交 ● 142.环形链表II
- CS224W5.1——消息传递和节点分类
- Vue报错解决Error in v-on handler: “Error: 无效的节点选择器:#div1“
猜你感兴趣
版权申明
本文"计算二叉树中最后一层的叶子节点的个数:层序遍历":http://eshow365.cn/6-11871-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!