[数据结构-hash]CF 7D Palindrome Degree

D. Palindrome Degree
time limit per test   1 second
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.
Input
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 exceed5•106. The string is case-sensitive.
Output
Output the only number — the sum of the polindrome degrees of all the string's prefixes.
Sample test(s)
input
a2A
output
1
input
abacaba
output
6

你可能感兴趣的:([数据结构-hash]CF 7D Palindrome Degree)