Loading [MathJax]/jax/output/HTML-CSS/jax.js

Problem I: Making Pairs

Problem

本日、ついに完全招待制の高級レストラン「マイヅレストラン」がオープンした。新たな会員を招待する権利を持つのはこのレストランの会員のみで、最初、会員は会員番号0であるレストランのオーナーのみである。

マイヅレストランはその高級さ故、オープン初日からN日間しか開かれない。その期間中、毎日会員のうち誰か一人が、自分の友人を一人だけ新たに会員として招待する。i日目に招待された会員には会員番号iが割り当てられ、その会員は招待された日を含めそれ以降毎日来店する。

このレストランには二人用テーブルしか存在しないので、会員の人々はできるだけペアでテーブルを使用して食事をする。食事にはオーナーも参加するので、他の会員はオーナーとペアを組むこともできる。しかし、会員の人々は皆人見知りであり、自分を招待した友人か、自分が招待した友人としかペアを組みたがらない。各会員はもし友人とペアを組めなかった場合、一人寂しく食事をする。

N日間の各日について、友人どうしのペアの数が最大となるようにペアを組んだとき、いくつのペアができるか求めよ。

Input

入力は以下の形式で与えられる。

N
p1
p2
...
pN

1行目にレストランが開かれる日数Nが与えられる。
続くN行に、会員番号がiの会員を招待した会員の会員番号piが与えられる。

Constraints

入力は以下の条件を満たす。

Output

出力はN行からなる。
i行目には、i日目に作ることのできる友人どうしのペアの最大数を出力する。 (1iN)

Sample Input 1

3
0
0
2

Sample Output 1

1
1
2

Sample Input 2

5
0
1
2
3
4

Sample Output 2

1
1
2
2
3