POJ 2406 Power Strings 暴力

emmmm

显然的是a串长度是s串长度的因数

我们可以暴力枚举因数然后暴力check

 1 #include<cstdio>
 2 #include<algorithm>
 3 #include<cstring>
 4 #define N 1000010
 5 #define Max(a,b,c) max(max(a,b),c)
 6 using namespace std;
 7 char s[N];
 8 int n;
 9 int check(int x)
10 {
11     for (int i=1;i<=n-x;i++)
12     if (s[i]!=s[i+x]) return 0;
13     return 1;
14 }
15 int main()
16 {
17     while (scanf("%s",s+1) && s[1]!='.')
18     {
19     n=strlen(s+1);
20     int ans=1;
21     for (int i=1;i*i<=n;i++)
22         if (n%i==0)
23         ans=Max(ans,check(i)*n/i,check(n/i)*i);
24     printf("%d
",ans);
25     }
26     return 0;
27 }
原文地址:https://www.cnblogs.com/mrsheep/p/7856237.html