Prefix

TimeLimit:3000MS  MemoryLimit:524MB
64-bit integer IO format:%I64d
未提交 | 登录后收藏
Problem Description

Given a string s, xzz want to know how many different string a, where f(a,s) = i and length of a is n. f(a,s) means the longest length of |s1|, which string s1 is the substring of string a and the prefix of string s. xzz is lazy, so you need to tell him answer from i = 0 to i = |s|. xzz is kind, so string a and string s can only consist of the uppercase letter.

经典的kmp(或自动机)->转移图->转移矩阵->矩阵快速幂

Input

First line of the input file contains an integer T(0 < T ≤ 100) that indicates how many cases of inputs are there.

The description of each case is given below:

The first line of each input case contains number n, m, n means the length of a and m means the length of s, n ≤ 10000000.

The second line of each input case contains string s, |s| ≤ 15.

Output

The description of output for each test case is given below:

each case contains |s| + 1 lines.

The i-th line of the output for each test case contains number A, means numbers of different string a, where f(a,s) = i - 1.

The result is too big, so you only to print the result modulo 10^9 + 7.

SampleInput
1
2 2
AC
SampleOutput
625
50
1
Submit
题目统计信息详细
总AC数2
通过人数2
尝试人数2
总提交量3
AC率66.67%
AC该题后可以添加标签
贴完标签可以获得20ACB。
并且可以获得本题所有提交代码查看权限。
点击标题可以显示标签。
如果你还没认真思考过这题,请不要查看标签
如果您已经通过了该题,请务为该题贴上标签

T^T Online Judge

[BUG反馈] [FAQ] [闽ICP备17026590号-1]
当前版本:3.24 系统时间: