시간 제한 메모리 제한 제출 정답 맞은 사람 정답 비율
2 초 512 MB 0 0 0 0.000%

문제

One day, Homer was bored in his house and decided to go in a journey to discover the lands of Springfield. The lands of Springfield is an infinite grid. Homer’s house is located at cell (0, 0) and his journey consisted of N steps, where each step is either move one cell right or one cell down.

Being bored already, Homer didn’t want his journey to be boring as well. He decided he won’t move in the same direction for more than K consecutive steps. Thus, a journey is considered to be interesting if for each K + 1 consecutive steps Homer has moved in both directions.

Figure 1: Example with N = 5 and K = 2 (first test case)

Given N and K, count the number of interesting journeys Homer can make. Two Journeys are considered different if for some i the i-th step in the first Journey differs from that of the second Journey. Since the number can be large, print it modulo 1,000,000,007.

입력

Your program will be tested on one or more test cases. The first line of the input will be a single integer T, the number of test cases (1 ≤ T ≤ 500), followed by T test cases.

Each test case will be presented on a single line containing two integers separated by a single space. The first integer will denote the number of steps in Homer’s journey N, followed by the second integer K representing the maximum number of consecutive steps Homer can take while moving in the same direction, where (0 ≤ N ≤ 105) and (0 ≤ K ≤ 105).

출력

For each test case, output a single line denoting the number of different journeys Homer can make modulo 1,000,000,007.

예제 입력 1

2
5 2
10 1


예제 출력 1

16
2