406727: GYM102511 G First of Her Name

Memory Limit:512 MB Time Limit:10 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

G. First of Her Nametime limit per test10 secondsmemory limit per test512 megabytesinputstandard inputoutputstandard output

In the Royal Family, names are very important! As the Royal Historian you have been charged with analyzing the patterns in the names of the Royal Ladies in the realm.

There have been n Royal Ladies, for convenience numbered from 1 to n. The name of each Lady is an uppercase letter concatenated with the name of her mother. The exception is the Lady numbered 1, the founder of the Royal Family, whose name is just a single uppercase letter.

For example, ENERYS could be the mother of AENERYS (as the name AENERYS consists of the single uppercase letter 'A' concatenated with ENERYS, which is her mother's name). Similarly, AENERYS could be the mother of DAENERYS and YAENERYS.

You are given the description of all the Royal Ladies. Your task is to determine, for certain interesting strings $$$s$$$, the number of Royal Ladies for whom $$$s$$$ is a prefix of their name.

For example, consider Sample Input 1 below, with a Royal Line that goes straight from the founder S to AENERYS (through YS, RYS, ERYS, NERYS and ENERYS), with each Lady having exactly one daughter. Then AENERYS has two daughters—DAENERYS and YAENERYS, with the latter having one daughter, RYAENERYS.

In such a family, RY is a prefix of the names of two ladies: RYS and RYAENERYS. E is a prefix of the names of ERYS and ENERYS. N is a prefix only of NERYS's name, while S is a prefix only of the name of the founder, S. AY is not a prefix of any Royal Lady's name.

Input

The first line of input contains two integers $$$n$$$ and $$$k$$$, where $$$n$$$ ($$$1 \le n \le 10^6$$$) is the total number of Royal Ladies and $$$k$$$ ($$$1 \le k \le 10^6$$$) is the number of query strings.

Then follow $$$n$$$ lines describing the Royal Ladies. The $$$i^{\text{th}}$$$ of these lines describes the Royal Lady numbered $$$i$$$, and contains an uppercase letter $$$c_i$$$ ('A' – 'Z') and an integer $$$p_i$$$ , where $$$c_i$$$ is the first letter of the name of Lady $$$i$$$, and $$$p_i$$$ ($$$p_1 = 0$$$ and $$$1 \le p_i < i$$$ for $$$i > 1$$$) is the number of her mother (or $$$0$$$, in the case of the First Lady). All the names are unique.

The remaining $$$k$$$ lines each contain one nonempty query string, consisting only of uppercase letters. The sum of the lengths of the query strings is at most $$$10^6$$$.

Output

Output $$$k$$$ lines, with the $$$i^{\text{th}}$$$ line containing the number of Royal Ladies who have the $$$i^{\text{th}}$$$ query string as a prefix of their name.

ExampleInput
10 5
S 0
Y 1
R 2
E 3
N 4
E 5
A 6
D 7
Y 7
R 9
RY
E
N
S
AY
Output
2
2
1
1
0

加入题单

算法标签: