CF1081H Palindromic Magic

Description

After learning some fancy algorithms about palindromes, Chouti found palindromes very interesting, so he wants to challenge you with this problem. Chouti has got two strings $ A $ and $ B $ . Since he likes [palindromes](https://en.wikipedia.org/wiki/Palindrome), he would like to pick $ a $ as some non-empty palindromic substring of $ A $ and $ b $ as some non-empty palindromic substring of $ B $ . Concatenating them, he will get string $ ab $ . Chouti thinks strings he could get this way are interesting, so he wants to know how many different strings he can get.

Input Format

The first line contains a single string $ A $ ( $ 1 \le |A| \le 2 \cdot 10^5 $ ). The second line contains a single string $ B $ ( $ 1 \le |B| \le 2 \cdot 10^5 $ ). Strings $ A $ and $ B $ contain only lowercase English letters.

Output Format

The first and only line should contain a single integer — the number of possible strings.

Explanation/Hint

In the first example, attainable strings are - "a" + "a" = "aa", - "aa" + "a" = "aaa", - "aa" + "aba" = "aaaba", - "aa" + "b" = "aab", - "a" + "aba" = "aaba", - "a" + "b" = "ab". In the second example, attainable strings are "aa", "aaa", "aaaa", "aaaba", "aab", "aaba", "ab", "abaa", "abaaa", "abaaba", "abab", "ba", "baa", "baba", "bb". Notice that though "a"+"aa"="aa"+"a"="aaa", "aaa" will only be counted once.