#374
Unrated
New Barns
시간 제한
2s
메모리 제한
1024MB
제출
0
정답
0
맞힌 사람
0
정답 비율
0.0%

문제

Farmer John notices that his cows tend to get into arguments if they are packed too closely together, so he wants to open a series of new barns to help spread them out.

Whenever FJ constructs a new barn, he connects it with at most one bidirectional pathway to an existing barn. In order to make sure his cows are spread sufficiently far apart, he sometimes wants to determine the distance from a certain barn to the farthest possible barn reachable from it (the distance between two barns is the number of paths one must traverse to go from one barn to the other).

FJ will give a total of QQ (1Q1051 \leq Q \leq 10^5) queries, each either of the form "build" or "distance". For a build query, FJ builds a barn and links it with at most one previously built barn. For a distance query, FJ asks you the distance from a certain barn to the farthest barn reachable from it via a series of pathways. It is guaranteed that the queried barn has already been built. Please help FJ answer all of these queries.

입력

The first line contains the integer QQ. Each of the next QQ lines contains a query. Each query is of the form "B p" or "Q k", respectively telling you to build a barn and connect it with barn pp, or give the farthest distance, as defined, from barn kk. If p=1p = -1, then the new barn will be connected to no other barn. Otherwise, pp is the index of a barn that has already been built. The barn indices start from 11, so the first barn built is barn 11, the second is barn 22, and so on.

출력

Please write one line of output for each distance query. Note that a barn which is connected to no other barns has farthest distance 00.

예제 입력 1

7
B -1
Q 1
B 1
B 2
Q 3
B 2
Q 2

예제 출력 1

0
2
1
코드 제출

코드를 제출하려면 로그인이 필요합니다.

로그인
내 제출
제출 내역이 없습니다.
맞은 사람
아직 맞은 사람이 없습니다.
난이도 투표
Unrated0명 투표
로그인 후 AC 받으면 투표할 수 있습니다.
전체 제출
제출 내역이 없습니다.