目录
题目描述
给定一个字符串,求需要添加至少几个字符到字符串末尾才能使得整个字符串串由某一个不为本身的子串循环构成?
如"abca",添加"bc"后构成"abcabc",其由子串"abc"循环构成;也可以添加"abca"后构成"abcaabca",其由子串"abca"循环构成,相比之下"bc"只有2个字符,添加的字符量最少。
输入
第一行包括一个整数T(1 <= T <= 100),代表测试组数
每组测试数据包括一行字符串,其长度范围为 [3, 10^4]
输出
对于每组测试数据
输出一个整数N,代表添加的最小字符数量
输入样例
3
aaa
abca
abcdefg
输出样例
0
2
7
思路分析
利用next值的含义。L为最小子串的长度。num为应添加的字符个数。
AC代码
#include <iostream>
#include <string>
using namespace std;
void GetNext(string p, int next[])
{
next[0] = -1;
int i, j;
int len = p.size();
i = 0;
j = -1;
while (i < len)
{
if (j == -1 || p[i] == p[j])
{
++i;
++j;
next[i] = j;
}
else
j = next[j];
}
}
int main()
{
int t;
cin >> t;
string s;
int next[10000] = {0};
int num, len;
while (t--)
{
num = 0;
cin >> s;
GetNext(s, next);
len = s.size();
// cout<<next[len]<<endl;
int L = len - next[len];
if (len % L == 0 && len / L > 1)
num = 0;
else
num = L - next[len] % L;
cout << num << endl;
}
return 0;
}