Abbyy Cup 2.0 - Final (unofficial) |
---|
Finished |
The Smart Beaver from ABBYY has come up with a new developing game for children. The Beaver thinks that this game will help children to understand programming better.
The main object of the game is finite rooted trees, each of their edges contains some lowercase English letter. Vertices on any tree are always numbered sequentially from 1 to m, where m is the number of vertices in the tree. Before describing the actual game, let's introduce some definitions.
We'll assume that the sequence of vertices with numbers v_{1}, v_{2}, ..., v_{k} (k ≥ 1) is a forward path, if for any integer i from 1 to k - 1 vertex v_{i} is a direct ancestor of vertex v_{i + 1}. If we sequentially write out all letters from the the edges of the given path from v_{1} to v_{k}, we get some string (k = 1 gives us an empty string). We'll say that such string corresponds to forward path v_{1}, v_{2}, ..., v_{k}.
We'll assume that the sequence of tree vertices with numbers v_{1}, v_{2}, ..., v_{k} (k ≥ 1) is a backward path if for any integer i from 1 to k - 1 vertex v_{i} is the direct descendant of vertex v_{i + 1}. If we sequentially write out all the letters from the edges of the given path from v_{1} to v_{k}, we get some string (k = 1 gives us an empty string). We'll say that such string corresponds to backward path v_{1}, v_{2}, ..., v_{k}.
Now let's describe the game that the Smart Beaver from ABBYY has come up with. The game uses two rooted trees, each of which initially consists of one vertex with number 1. The player is given some sequence of operations. Each operation is characterized by three values (t, v, c) where:
The actual operation is as follows: vertex v of tree t gets a new descendant with number m + 1 (where m is the current number of vertices in tree t), and there should be letter c put on the new edge from vertex v to vertex m + 1.
We'll say that an ordered group of three integers (i, j, q) is a good combination if:
Your task is to calculate the number of existing good combinations after each operation on the trees.
The first line contains integer n — the number of operations on the trees. Next n lines specify the operations in the order of their execution. Each line has form "t v c", where t is the number of the tree, v is the vertex index in this tree, and c is a lowercase English letter.
To get the full points for the first group of tests it is sufficient to solve the problem with 1 ≤ n ≤ 700.
To get the full points for the second group of tests it is sufficient to solve the problem with 1 ≤ n ≤ 7000.
To get the full points for the third group of tests it is sufficient to solve the problem with 1 ≤ n ≤ 100000.
Print exactly n lines, each containing one integer — the number of existing good combinations after the corresponding operation from the input.
Please, do not use the %lld specifier to read or write 64-bit integers in С++. It is preferred to use the cin, cout streams or the %I64d specifier.
5
1 1 a
2 1 a
1 2 b
2 1 b
2 3 a
1
3
3
4
7
After the first operation the only good combination was (1, 1, 1). After the second operation new good combinations appeared, (2, 1, 2) and (1, 2, 2). The third operation didn't bring any good combinations. The fourth operation added good combination (1, 3, 3). Finally, the fifth operation resulted in as much as three new good combinations — (1, 4, 4), (2, 3, 4) and (3, 1, 4).
Name |
---|