No tag edit access

E. Mr. Kitayuta's Gift

time limit per test

6 secondsmemory limit per test

768 megabytesinput

standard inputoutput

standard outputMr. Kitayuta has kindly given you a string *s* consisting of lowercase English letters. You are asked to insert exactly *n* lowercase English letters into *s* to make it a palindrome. (A palindrome is a string that reads the same forward and backward. For example, "noon", "testset" and "a" are all palindromes, while "test" and "kitayuta" are not.) You can choose any *n* lowercase English letters, and insert each of them to any position of *s*, possibly to the beginning or the end of *s*. You have to insert exactly *n* letters even if it is possible to turn *s* into a palindrome by inserting less than *n* letters.

Find the number of the palindromes that can be obtained in this way, modulo 10007.

Input

The first line contains a string *s* (1 ≤ |*s*| ≤ 200). Each character in *s* is a lowercase English letter.

The second line contains an integer *n* (1 ≤ *n* ≤ 10^{9}).

Output

Print the number of the palindromes that can be obtained, modulo 10007.

Examples

Input

revive

1

Output

1

Input

add

2

Output

28

Note

For the first sample, you can obtain the palindrome "reviver" by inserting 'r' to the end of "revive".

For the second sample, the following 28 palindromes can be obtained: "adada", "adbda", ..., "adzda", "dadad" and "ddadd".

Codeforces (c) Copyright 2010-2017 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Jun/28/2017 08:29:29 (p1).

Desktop version, switch to mobile version.
User lists

Name |
---|