쿠옹이는 어느 날 갑자기 이런 궁금증이 들었다. '연산 결과가 N이 되는 수식은 몇 개가 있을까?'
쿠옹이는 연산 결과가 N이 되는 수식의 뒤에 +0, -0 등을 이어 붙이면 여전히 연산 결과가 N이므로 이 시행을 반복하면 연산 결과가 N인 수식을 무한히 만들 수 있다는 슬픈 사실을 깨닫고 말았다.
그래서 쿠옹이는 수식의 길이가 M이어야 한다는 제약을 추가했지만 이번에는 답을 내지 못했다. 여러분이 대신 이 문제를 풀어 주자!
수식은 다음과 같이 정의된다.
다르게 설명하면 수식은 다음 정규식을 만족하는 문자열을 말한다.
첫째 줄에 N과 M이 공백으로 구분되어 주어진다. (0 ≤ N ≤ 105, 1 ≤ M ≤ 11)
길이 M의 연산 결과가 N이 되는 서로 다른 수식의 수를 출력하라. 이때 그러한 수식이 아주 많을 수 있으므로 109 + 7로 나눈 나머지를 대신 출력하라.
5 3
11
123 3
1
100000 5
0
0 2
0
10 3
9
예제 1: 길이 3의 연산 결과가 5가 되는 수식은 0+5, 1+4, 2+3, 3+2, 4+1, 5+0, 5-0, 6-1, 7-2, 8-3, 9-4의 11개이다.
예제 2: 수식은 +나 -를 포함하지 않을 수도 있다.
예제 5: 수식은 +나 -로 시작할 수 없다.
| Название |
|---|


