loj#P2065. 「SDOI2016」模式字符串
「SDOI2016」模式字符串
题目描述
给出 个结点的树结构 ,其中每一个结点上有一个字符,这里我们所说的字符只考虑大写字母 A 到 Z ,再给出长度为 的模式串 ,其中每一位仍然是 A 到 Z 的大写字母。
Alice 希望知道,有多少对结点 满足 上从 到 的最短路径形成的字符串可以由模式串 重复若干次得到?这里结点对 是有序的,也就是说 和 需要被区分。所谓模式串的重复,是将若干个模式串 依次相接(不能重叠)。例如当 PLUS
的时候,重复两次会得到 PLUSPLUS
,重复三次会得到 PLUSPLUSPLUS
。同时要注意,重复必须是整数次的。例如当 XYXY
时,因为必须重复整数次,所以 XYXYXY
不能看作是 重复若干次得到的。
输入格式
每一个数据有多组测试,
第一行输入一个整数 ,表示总的测试个数。
对于每一组测试来说:
第一行输入两个整数,分别表示树 的结点个数 与模式长度 。结点被依次编号为 到 ;
之后一行,依次给出了 个大写字母(以一个长度为 的字符串的形式给出),依次对应树上每一个结点上的字符(第 个字符对应了第 个结点)。
之后 行,每行有两个整数 和 表示树上的一条无向边,之后一行给定一个长度为 的由大写字母组成的字符串,为模式串 。
输出格式
给出 行,对应 组测试。每一行输出一个整数,表示有多少对节点 满足从 到 的路径形成的字符串恰好是模式串的若干次重复。
1
11 4
IODSSDSOIOI
1 2
2 3
3 4
1 5
5 6
6 7
3 8
8 9
6 10
10 11
SDOI
5
数据范围与提示
对于所有的数据,$1 \leq C \leq 10, \ 3 \leq \sum n \leq 1000000, 3 \leq \sum M \leq 1000000$。