#P11162. 「BalkanOI 2023 Day1」Car Race

「BalkanOI 2023 Day1」Car Race

题目描述

译自 BalkanOI 2023 Day1 T1「Car Race

为了吸引更多的游客和资金到曾经骄傲但现在几乎被废弃的马里博尔工业区,这座城市在前 Metalna 工厂的地点建了一条赛道(Metalna 工厂是 1990 年代初被迫关闭的多家马里博尔大型企业之一)。赛道的形状是一棵有 nn 个顶点的有根树。树的顶点用整数 0,1,,n10,1, \ldots, n-1 编号,根的编号是 00

比赛开始了!最初,有些顶点上有赛车。每秒,每辆赛车都向着根的方向移动到相邻的顶点。在任何时刻,如果两辆或更多的赛车同时在一个编号大于 00 的顶点上,它们就会相撞,不能再参加比赛。根上可以在任何时刻容纳任意数量的赛车。

对于每个顶点 vv,输出一个整数 cvc_{v},它的定义如下:

  • 如果在比赛开始时顶点 vv 上没有赛车,cvc_{v}1-1
  • 否则,如果从顶点 vv 出发的赛车在到达根的途中相撞,那么 cvc_{v}1-1
  • 否则,cvc_{v} 是从顶点 vv 出发的赛车到达根的时间。

输入格式

第一行包含一个整数 nn,表示树的顶点数。

第二行包含 n1n-1 个整数 p1,p2,,pn1p_{1}, p_{2}, \ldots, p_{n-1}pi (1in1)p_{i}\ (1\leq i\leq n-1) 表示顶点 ii 的父亲,满足 0pi<i0 \leq p_{i}<i

第三行包含 nn 个整数 a0,a1,,an1a_{0}, a_{1}, \ldots, a_{n-1}。如果在比赛开始时顶点 ii 上有赛车 ai=1a_{i}=1;否则 ai=0a_{i}=0

输出格式

输出一行包含 nn 个整数 c0,c1,,cn1c_{0}, c_{1}, \ldots, c_{n-1},整数之间用一个空格分隔。

5
0 1 1 3
0 1 1 1 1
-1 1 -1 -1 3

提示

样例解释

顶点 00(根)在比赛开始时没有赛车。从顶点 11 出发的赛车到达根需要 11 秒,从顶点 44 出发的赛车需要 33 秒。从顶点 2 和 33 出发的赛车在到达根的途中在顶点 11 相撞。

数据范围

对于所有输入数据,满足:

  • 1n1061 \leq n \leq 10^{6}

详细子任务附加限制及分值如下表所示。

子任务编号 附加限制 分值
11 n3n \leq 3 33
22 pi=i1 (1in1)p_{i}=i-1\ (1\leq i\leq n-1) 55
33 n500n \leq 500 88
44 n3000n \leq 3000 99
55 n105n \leq 10^{5} 1010
66 pi=i12p_{i}=\frac{i-1}{2} 99
77 n2105n \leq 2 \cdot 10^{5} 1414
88 每个顶点最多有 33 个相邻的点 1919
99 无附加限制 2323