Logo HelloWorld信息学奥赛题库

少儿编程

时间限制:1 s 空间限制:128 MB

#3521. 「POI2012」工资 Salaries

Statistics

题目描述

译自 POI 2012 Stage 3. Day 1「Salaries

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

输入格式

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

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

输出格式

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

样例

input

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

output

2
10
1
9
5
8
0
0
0
0

数据范围与提示

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

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