求一个字符串的最小循环节
Posted oc_co
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了求一个字符串的最小循环节相关的知识,希望对你有一定的参考价值。
#include <bits/stdc++.h> #define ll long long #define inf 0x3f3f3f3f #define met memset(a,0,sizeof(a)) using namespace std; const int mod=1e9+7; char str[100000]; int nex[100000]; void getnext(int len) { int j=0,k=-1; nex[0]=-1; while(j<len) { if(k==-1||str[j]==str[k]) nex[++j]=++k; else k=nex[k]; } } int main() { std::ios::sync_with_stdio(false); std::cin.tie(0); int i,j,k,m,n; cin>>str; n=strlen(str); getnext(n); int x=n-nex[n]; cout<<x<<endl; return 0; }
以上是关于求一个字符串的最小循环节的主要内容,如果未能解决你的问题,请参考以下文章