Hide

Problem A
Hash

Little Mirko is studying the hash function which associates numerical values to words. The function is defined recursively in the following way:

  • f(empty word)=0

  • f(word+letter)=((f(word)33)ord(letter))%MOD

The function is defined for words that consist of only lowercase letters of the English alphabet. stands for the bitwise exclusive or operator (i.e. 01101010=1100), ord(letter) stands for the ordinal number of the letter in the alphabet (ord(a)=1, ord(z)=26) and A%B stands for the remainder of the number A when performing integer division with the number B. MOD will be an integer of the form 2M.

Some values of the hash function when M = 10:

  • f(a)=1

  • f(aa)=32

  • f(kit)=438

Mirko wants to find out how many words of the length N there are with the hash value K. Write a programme to help him calculate this number.

Input

The first line of input contains three integers N, K and M (1N10, 0K<2M, 6M25).

Output

The first and only line of output must consist of the required number from the task.

Sample Input 1 Sample Output 1
1 0 10
0
Sample Input 2 Sample Output 2
1 2 10
1
Sample Input 3 Sample Output 3
3 16 10
4
Hide

Please log in to submit a solution to this problem

Log in