#P50800. 「POI2012」工资 Salaries

「POI2012」工资 Salaries

题目描述

译自 POI 2012 Stage 3. Day 1「Salaries

有一个 nn 个点的有根树,每个点的权值分别为 1n1 \ldots n,且大于其儿子的权值。其中一部分点的权值是公开的,且每个权值已知的点的父亲权值也一定已知。求能够根据已知信息推算出来的权值未知的点的权值。

输入格式

第一行一个整数 nn,表示点的个数。

接下来 nn 行每行两个整数 pi,zi(1pin,0zin)p_i, z_i (1 \le p_i \le n,0 \le z_i \le n),其中 pip_i 表示结点 ii 的父亲,ziz_i 表示结点 ii 的权值。如果 zi=0z_i = 0,则该点权值未知,否则该点权值为 ziz_i

输出格式

输出 nn 行,每行一个整数,表示 ii 点的权值。如果该点权值已知或可以推算出来,输出该点权值,否则输出 00

样例

10
2 2
2 10
1 0
2 9
2 5
4 0
6 0
6 0
5 0
5 0
2
10
1
9
5
8
0
0
0
0

数据范围与提示

对于 54%54\% 的数据有 n104n \le 10^4.

对于所有数据有 1n1061 \le n \le 10^6