题目链接:洛谷p4391
题目描述
给你一个字符串,它是由某个字符串不断自我连接形成的。 但是这个字符串是不确定的,现在只想知道它的最短长度是多少.
输入格式
第一行给出字符串的长度,1 < L ≤ 1,000,000.
第二行给出一个字符串,全由小写字母组成.
输出格式
输出最短的长度
输入输出样例
输入
8
cabcabca
输出
3
说明/提示
对于样例,我们可以利用"abc"不断自我连接得到"abcabcabc",读入的cabcabca,是它的子串
解析链接;洛谷解析
按照题意,读入字符串长度n和字符串s ;
这道题求的是字符串ss最小长度的循环,我们称之为“s的循环子串”,首先引入结论:
ans=n-next[n]
求出next数组(其实只求出next[n]就行了),即求出字符串的最大公共前后缀;
ac代码
# include<bits/stdc++.h>
using namespace std;
const int maxn=1e6+10;
int nex[maxn];
char s[maxn],p[maxn];
int sLen,pLen;
void GetNext(char* p)
{
nex[0] = -1;
int k = -1;
int j = 0;
while (j < pLen)
{
if (k == -1 || p[j] == p[k])
{
++k;
++j;
nex[j] = k;
}
else
{
k = nex[k];
}
}
}
//int KmpSearch(char* s, char* p)
//{
// int i = 0;
// int j = 0;
// while (i < sLen&& j < pLen )
// {
// if (j == -1 || s[i] == p[j])
// {
// i++;
// j++;
// }
// else
// {
// j = nex[j];
// }
// }
// if (j == pLen)
// return i - j;
// else
// return -1;
//}
int main(){
int n;
cin>>n;
cin>>p;
pLen=strlen(p);
GetNext(p);
for(int i=1;i<=pLen;i++){
cout<<nex[i]<<' ';
}
return 0;
}
阿里云建站—为企业提供互联网“快”服务
2020年因为一场突如其来的疫情,不少企业受到了严重冲击,疫情的冲击力对传统“纯线
下”行业的危害最大,互联网女皇玛丽·米克(MaryMeeker)4月17日发布了著名的年度互
联网趋势报告,报告中指出:拥有强大的互联网线上线下融合能力的企业在疫情中的表现最好,
线上线下融合的趋势已经存在一段时间了,但是疫情让这种需求变得更加的迫切。
如果你的企业完全依附于传统的、纯线下的经验模式,那么在2020年你将“必死无疑”,
一场巨大的,前所未有的互联网革命已经到来!
阿里云建站为了助力各行各业复工复产,疫情期间“马不停蹄”为数以万计的企业快速完成
建站,为他们朝着“线上线下融合”或者“纯线上”的互联网经营模式迈进,打下了坚实的基础。
“云·速成美站”模板建站1天就能上线,不懂技术没关系,打字就能建网站。千套网站模
板免费提供,百元就能建官网,一价全包,无任何隐形消费。
“云·企业官网”定制建站1周就能上线,高端量身定制建站,千元建官网无需自己动手,
建站专家1对1网站策划及设计,专业省心之选。
疫情,是一场大浪淘沙,每一次危机背后都隐藏着机会,危机越大,机会也越大。大环境
已经改变,如果你不努力不去改变来迎合这个大环境,那你必将被淘汰。
阿里云助力企业建站,优惠多多,福利多多,详情请点击如下链接
https://www.aliyun.com/minisite/goods?userCode=dnw32bz9