#P5341. [TJOI2019] 甲苯先生和大中锋的字符串

[TJOI2019] 甲苯先生和大中锋的字符串

题目背景

TJOI2019 D2T2

源文件名:substring.*

时间限制: 1s 内存限制: 128M

题目描述

大中锋有一个长度为 nn 的字符串,他只知道其中的一个子串是祖上传下来的宝藏的密码。但是由于字符串很长,大中锋很难将这些子串一一尝试。

这天大中锋找到甲苯先生算命,但是甲苯先生说:“天机不可泄漏”。

在大中锋的苦苦哀求下,甲苯先生告诉大中锋:“密码是在字符串中恰好出现了 kk 次的子串”。

但是大中锋不知道该怎么做,在大中锋再三的恳求下,甲苯先生看其真诚,又告诉他:“在恰好出现了 kk 次的子串中,你去按照字串的长度分类,密码就在数量最多的那一类里”。

大中锋为了尝试这个密码,想让你帮忙找出子串长度出现次数最多的长度数(如果有多个输出最长长度)。

输入格式

第一行一个正整数 TT ,表示有 TT 组测试数据。

接下来 TT 行每行包含一个字符串和一个正整数 kk

输出格式

一共输出 TT 行,每行一个整数表示在出现 kk 次的子串中出现次数的最多的长度。如果不存在子串出现 kk 次,则输出 1-1

6
aab 1
abc 1
aaaa 2
abab 2
ababacc 2
abab 4
2
1
3
1
2
-1

提示

数据说明

对于第一个数据:其中子串 b,aa,ab,aabb, aa, ab, aab 均只出现一次,其中长度为 11 的子串出现了 11 次,长度为 22 的子串出现了 22 次,长度为 33 的子串出现了 11 次。所以答案为 22

对于第二个数据:其中子串 a,b,c,ab,bc,abca, b, c, ab, bc, abc 均只出现一次,其中长度为 11 的子串出现了 33 次,长度为 22 的子串出现了 22 次,长度为 33 的子串出现了 11 次。所以答案为 11

对于第三个数据:其中子串 aaaaaa 出现二次,长度为 33 的子串出现了 11 次,其他长度均没有。所以答案为 33

对于第四个数据:其中子串 a,b,aba, b, ab 出现二次,其中长度为 11 的子串出现了 22 次,长度为 22 的子串出现了 11 次。所以答案为 11

对于第五个数据:其中子串 b,c,ab,bab, c, ab, ba 出现二次,其中长度为 11 的子串出现了 22 次,长度为 22 的子串出现了 22 次。所以答案为 22

对于第六个数据:其中子串没有出现四次。所以本题的本题的答案为 1-1

数据范围

对于 20%20\% 的数据, 1kn101\leq k\leq n\leq 10

对于 100%100\% 的数据, $1\leq n\leq 10^5,1 \leq T \leq 100,\sum n \leq 3 * 10^6$ ,输入的字符串中仅包含小写英文字母。