【题目描述】
String s of length n is called k-palindrome, if it is a palindrome itself, and its prefix and suffix of length are (k - 1)-palindromes. By definition, any string (even empty) is 0-palindrome.
Let’s call the palindrome degree of string s such a maximum number k, for which s is k-palindrome. For example, “abaaba” has degree equals to 3.
You are given a string. Your task is to find the sum of the palindrome degrees of all its prefixes.
【输入】
The first line of the input data contains a non-empty string, consisting of Latin letters and digits. The length of the string does not exceed 5·106. The string is case-sensitive.
【输出】
Output the only number — the sum of the polindrome degrees of all the string’s prefixes.
【样例输入】
a2A
【样例输出】
1
【样例输入】
abacaba
【样例输出】
6
题目链接:https://codeforces.com/contest/7/problem/D
代码如下:
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
static const int SEED=103;
static const int MAXN=5000000;
ll f[MAXN+10];
int dp[MAXN+10];
char s[MAXN+10];
int main()
{
scanf("%s",s); //string和cin都会T
int len=strlen(s);
f[0]=1;
for(int i=1;i<len;i++)
f[i]=f[i-1]*SEED;
ll pre=0,tail=0,ans=0;
for(int i=0;i<len;i++)
{
pre=pre*SEED+s[i];
tail=tail+f[i]*s[i];
if(pre==tail)
{
dp[i+1]=dp[i+1>>1]+1;
ans+=dp[i+1];
}
}
cout<<ans<<endl;
return 0;
}