#P15600. [ICPC 2020 Jakarta R] Tree Beauty
[ICPC 2020 Jakarta R] Tree Beauty
说明
有一棵有根树,包含 个顶点,编号从 到 。顶点 是树的根,对于所有 , 是顶点 的父节点。每个顶点都有一个美丽值,初始为 。
你可以使用一台特殊机器来增加顶点的美丽值。向机器提供三个参数 、 和 ,机器将增加顶点 的子树中所有顶点的美丽值。如果顶点 位于顶点 的子树中,则其美丽值将增加 ,其中 是连接顶点 到 的路径上的边数。例如,顶点 的美丽值增加 ,顶点 的所有子节点的美丽值增加 ,顶点 的子节点的所有子节点的美丽值增加 ,以此类推。
你将依次执行 次操作。每次操作是以下类型之一:
- 使用特殊机器,向机器提供三个参数 、 和 。
- 报告顶点 的子树中所有顶点的美丽值总和。
对于每个第二类操作,输出顶点 的子树中所有顶点的美丽值总和。
输入格式
输入第一行包含两个整数 和 (),分别表示顶点数量和操作数量。下一行包含 个整数 (),表示顶点 的父节点;注意 从 开始。接下来 行,每行包含以下格式之一,表示你要执行的操作:
- (;)
使用特殊机器,向机器提供三个参数 、 和 。 - ()
输出顶点 的子树中所有顶点的美丽值总和。
保证至少有一个第二类操作。
输出格式
对于每个第二类操作,按输入顺序输出一行一个整数,表示顶点 的子树中所有顶点的美丽值总和。
5 5
1 1 3 3
1 1 99 2
2 1
2 3
1 3 2 3
2 3
245
97
99
提示
样例 #1 解释
树的结构如下图所示:
:::align{center}
:::
- 第一次操作使顶点 的美丽值增加 ,顶点 和 增加 ,顶点 和 增加 。
- 顶点 的子树中所有顶点的美丽值总和为 。
- 顶点 的子树中所有顶点的美丽值总和为 。
- 第四次操作使顶点 的美丽值增加 ,顶点 和 增加 。
- 顶点 的子树中所有顶点的美丽值总和为 。
翻译由 DeepSeek 完成
京公网安备 11011102002149号