华为OD机考:统一考试 D卷 + C卷 + B卷 +A卷
真题目录:华为OD机考机试 真题目录(C卷 + D卷 + B卷 + A卷) + 考点说明
题目描述
给定一个二叉树,每个节点上站一个人,节点数字表示父节点到该节点传递悄悄话需要花费的时间。
初始时,根节点所在位置的人有一个悄悄话想要传递给其他人,求二叉树所有节点上的人都接收到悄悄话花费的时间。
输入描述
给定二叉树
0 9 20 -1 -1 15 7 -1 -1 -1 -1 3 2
注:-1表示空节点
输出描述
返回所有节点都接收到悄悄话花费的时间
38
用例
输入 | 0 9 20 -1 -1 15 7 -1 -1 -1 -1 3 2 |
---|---|
输出 | 38 |
说明 | 无 |
解题思路
- 读取输入:
- 读取一行输入,这行输入包含了一系列的整数,每个整数代表从父节点到子节点的悄悄话传递时间。
- 处理根节点:
- 将根节点(索引为0)加入队列,并设置其悄悄话接收时间为0。
- 层次遍历:
- 当队列不为空时,循环执行以下步骤:
- 从队列中取出一个节点(包括节点索引和该节点的悄悄话接收时间)。
- 计算左右子节点的索引。
- 检查左右子节点是否存在(索引有效且不为-1)。
</
- 当队列不为空时,循环执行以下步骤: