#D9367. Unhappy Hacking

    ID: 7787 Type: Default 2000ms 268MiB

Unhappy Hacking

Unhappy Hacking

Sig has built his own keyboard. Designed for ultimate simplicity, this keyboard only has 3 keys on it: the 0 key, the 1 key and the backspace key.

To begin with, he is using a plain text editor with this keyboard. This editor always displays one string (possibly empty). Just after the editor is launched, this string is empty. When each key on the keyboard is pressed, the following changes occur to the string:

  • The 0 key: a letter 0 will be inserted to the right of the string.
  • The 1 key: a letter 1 will be inserted to the right of the string.
  • The backspace key: if the string is empty, nothing happens. Otherwise, the rightmost letter of the string is deleted.

Sig has launched the editor, and pressed these keys N times in total. As a result, the editor displays a string s. Find the number of such ways to press the keys, modulo 10^9 + 7.

Constraints

  • 1 ≦ N ≦ 5000
  • 1 ≦ |s| ≦ N
  • s consists of the letters 0 and 1.

Input

The input is given from Standard Input in the following format:

N s

Output

Print the number of the ways to press the keys N times in total such that the editor displays the string s in the end, modulo 10^9+7.

Examples

Input

3 0

Output

5

Input

300 1100100

Output

519054663

Input

5000 01000001011101000100001101101111011001000110010101110010000

Output

500886057

inputFormat

Input

The input is given from Standard Input in the following format:

N s

outputFormat

Output

Print the number of the ways to press the keys N times in total such that the editor displays the string s in the end, modulo 10^9+7.

Examples

Input

3 0

Output

5

Input

300 1100100

Output

519054663

Input

5000 01000001011101000100001101101111011001000110010101110010000

Output

500886057

样例

5000
01000001011101000100001101101111011001000110010101110010000
500886057