P2982 [USACO10FEB] Slowing down G

题目描述

每天,Farmer John 的 $N$ $(1 \le N \le 100{,}000)$ 头奶牛(方便地编号为 $1..N$)都会从牛棚走向各自的私人牧场。牧场形成一棵树,其中牛棚位于牧场 $1$。恰好有 $N-1$ 条无向路径连接这些牧场;直接相连的牧场之间恰好有一条路径。路径 $i$ 连接牧场 $A_i$ 和 $B_i$ $(1 \le A_i \le N, 1 \le B_i \le N)$。 奶牛 $i$ 拥有一个私人牧场 $P_i$ $(1 \le P_i \le N)$。牛棚的小门一次只能让一头奶牛出去,耐心的奶牛们会等待前一头奶牛到达她的私人牧场。首先,奶牛 $1$ 离开并走向牧场 $P_1$。接着奶牛 $2$ 离开并前往牧场 $P_2$,依此类推。 当奶牛 $i$ 走向 $P_i$ 时,她可能会经过已经有奶牛在进食的牧场。当一头奶牛出现在某个牧场时,奶牛 $i$ 在穿过该牧场时会比平时走得更慢,以避免打扰她的朋友。 ```cpp 考虑以下牧场网络,其中括号中的数字表示牧场的主人。 1 (3) / \ (1) 4 3 (5) / \ (2) 2 5 (4) 首先,奶牛 1 走向她的牧场: 1 (3) / \ [1] 4* 3 (5) / \ (2) 2 5 (4) 当奶牛 2 走向她的牧场时,她首先进入牛棚的牧场,即牧场 1。 然后她绕过牧场 4 中的奶牛 1,最终到达自己的牧场。 1 (3) / \ [1] 4* 3 (5) / \ [2] 2* 5 (4) 奶牛 3 根本没走远——她在牛棚的牧场 #1 里闲逛。 1* [3] / \ [1] 4* 3 (5) / \ [2] 2* 5 (4) 奶牛 4 在前往牧场 5 的路上,必须在牧场 1 和 4 放慢速度: 1* [3] / \ [1] 4* 3 (5) / \ [2] 2* 5* [4] 奶牛 5 因为在牧场 1 遇到奶牛 3 而放慢速度,然后进入自己的私人牧场: 1* [3] / \ [1] 4* 3*[5] / \ [2] 2* 5* [4] ``` FJ 想知道每头奶牛需要放慢多少次速度。

输入格式

- 第 1 行:一个整数 $N$。 - 第 $2..N$ 行:第 $i+1$ 行包含两个以空格分隔的整数 $A_i$ 和 $B_i$。 - 第 $N+1..N+N$ 行:第 $N+i$ 行包含一个整数 $P_i$。

输出格式

- 第 $1..N$ 行:第 $i$ 行包含奶牛 $i$ 需要放慢速度的次数。

说明/提示

数据范围:$1 \leq A_i, B_i, P_i \leq N \leq 10^5$。