#Lutece0356. Adjacent Bit Counts

Adjacent Bit Counts

Migrated from Lutece 356 Adjacent Bit Counts

All parts of this problem, including description, images, samples, data and checker, might be broken. If you find bugs in this problem, please contact the admins.

Description

For a string of n bits x1,x2,x3,,xnx_1, x_2, x_3, \cdots , x_n, the adjacent bit count of the string AdjBC(x)\rm AdjBC(x) is given by

$x_1\times x_2 + x_2\times x_3 + x_3\times x_4 + \cdots + x_{n-1}\times x_n$

which counts the number of times a 11 bit is adjacent to another 11 bit. For example:

  1. AdjBC(011101101)=3\rm AdjBC(011101101) = 3
  2. AdjBC(111101101)=4\rm AdjBC(111101101) = 4
  3. AdjBC(010101010)=0\rm AdjBC(010101010) = 0

Write a program which takes as input integers nn and kk and returns the number of bit strings xx of nn bits (out of 2n2n) that satisfy AdjBC(x)=k\rm AdjBC(x) = k. For example, for 55 bit strings, there are 66 ways of getting AdjBC(x)=2\rm AdjBC(x) = 2: 11100, 01110, 00111, 10111, 11101, 11011

Input

The first line of input contains a single integer PP, (1P10001\leq P\leq 1000), which is the number of data sets that follow. Each data set is a single line that contains the data set number, followed by a space, followed by a decimal integer giving the number (nn) of bits in the bit strings, followed by a single space, followed by a decimal integer (kk) giving the desired adjacent bit count. The number of bits (nn) will not be greater than 100100 and the parameters nn and kk will be chosen so that the result will fit in a signed 3232-bit integer.

Output

For each data set there is one line of output. It contains the data set number followed by a single space, followed by the number of nn-bit strings with adjacent bit count equal to kk.

Samples

10
1 5 2
2 20 8
3 30 17
4 40 24
5 50 37
6 60 52
7 70 59
8 80 73
9 90 84
10 100 90
1 6
2 63426
3 1861225
4 168212501
5 44874764
6 160916
7 22937308
8 99167
9 15476
10 23076518

Resources

Greater New York 2009