misc#P25017. 串串

串串

题目描述

给你 nn1n501 \leq n \leq 50)个仅有小写字母组成的字符串 s1,s2,,sns_1, s_2, \cdots, s_n,每个字符串的长度不一定相等。你需要选择一个字符串 tttt 不一定在 ss 中选)。神圣值 aa 的定义如下:

对于每个字符串 sis_i,你有两种选择:

  • 忽略这个字符串。此时该串的神圣值 ai=0a_i = 0
  • sis_i 中选择一个tt 相等的子串。假设你选的这个子串为 [L,R][L, R],那么 ai=La_i = L

你需要在选择至少两个串的前提下,最大化

t×i=1nai|t| \times \sum_{i = 1}^{n} a_i

输入格式

第一行输入一个整数 TT1T501 \le T \le 50),表示测试的总数。

对于每个测试样例, 第一行输入一个数 nn1n501 \leq n \leq 50) ,表示字符串的个数。

接下来 nn 行,每行一个字符串 sis_i1s1051 \leq |s| \leq 10^5)。

保证样例中 s1.1×106\sum |s| \leq 1.1 \times10^6

输出格式

对于每个样例,输出一个数,t×i=1nai|t| \times \sum_{i = 1}^{n} a_i 的最大值。若无法取到两个串,请输出 00

2
3
a
aa
aaa
1
abc
6
0

解释 #1

对于第一个样例,我们选择 t=aat = aa。这样神圣值可以选择为 aa = [0, 1, 2]。因此答案为 6。