You are given a non-empty string s consisting of lowercase letters. Find the number of pairs of non-overlapping palindromic substrings of this string.
In a more formal way, you have to find the quantity of tuples (a, b, x, y) such that 1 ≤ a ≤ b < x ≤ y ≤ |s| and substrings s[a... b], s[x... y] are palindromes.
A palindrome is a string that can be read the same way from left to right and from right to left. For example, "abacaba", "z", "abba" are palindromes.
A substrings[i... j] (1 ≤ i ≤ j ≤ |s|) of string s = s1s2... s|s| is a string sisi + 1... sj. For example, substring s[2...4] of string s = "abacaba" equals "bac".
Input
The first line of input contains a non-empty string s which consists of lowercase letters ('a'...'z'), s contains at most 2000 characters.
Output
Output a single number — the quantity of pairs of non-overlapping palindromic substrings of s.
Please do not use the %lld format specifier to read or write 64-bit integers in С++. It is preferred to use cin, cout streams or the %I64d format specifier.
#define CLR(x) memset(x,0,sizeof x) #define ll long long const int inf=0x3f3f3f3f; const int maxn=2e3+5; const int MOD=5e5+5; char str[maxn]; int l[maxn], r[maxn]; //l[i]表示以i开头的回文串的个数 //r[i]表示以i结尾的回文串的个数 //然后ans就是扫一遍,分别找到i之前回文串与i之后的回文串,乘起来,就是答案 int len; int main() { #ifdef LOCAL freopen("in.txt","r",stdin); //freopen("out.txt","w",stdout); #endif ios_base::sync_with_stdio(0);
while(scanf("%s", str) != EOF){ len = strlen(str); CLR(l),CLR(r); ll ans = 0; for(int i = 0; i < len; i++){ for(int a = i, b = i+1; a >= 0 && b < len && str[a] == str[b]; a--, b++){//偶数回文 l[a]++; r[b]++; } for(int a = i, b = i; a >= 0 && b < len && str[a] == str[b]; a--, b++){ l[a]++; r[b]++; } } for(int i = 1; i < len; i++) r[i] += r[i-1]; for(int i = 0; i < len; i++) ans += r[i] * l[i+1]; printf("%I64d\n", ans); }
DescriptionYou are given a non-empty string s consisting of lowercase letters. Find the number of pairs of non-overlapping palindromic substrings of this string.In a more formal way, you hav