Олимпиадный тренинг

Задача . C. Еще одна последовательность чисел


Все знают, что такое ряд чисел Фибоначчи. Это последовательность, которую можно определить следующим рекуррентным соотношением:

F1 = 1, F2 = 2, Fi = Fi - 1 + Fi - 2 (i > 2).

Определим новую последовательность чисел Ai(k) следующей формулой:

Ai(k) = Fi × ik (i ≥ 1).

В этой задаче вам требуется посчитать следующую сумму: A1(k) + A2(k) + ... + An(k). Ответ может быть очень большим, поэтому выведите его по модулю 1000000007 (109 + 7).

Входные данные

В первой строке записано два целых числа через пробел n, k (1 ≤ n ≤ 1017; 1 ≤ k ≤ 40).

Выходные данные

Выведите единственное целое число — сумму первых n элементов последовательности Ai(k) по модулю 1000000007 (109 + 7).


Примеры
Входные данныеВыходные данные
1 1 1
1
2 4 1
34
3 5 2
316
4 7 4
73825

time 1000 ms
memory 256 Mb
Правила оформления программ и список ошибок при автоматической проверке задач

Статистика успешных решений по компиляторам
 Кол-во
С++ Mingw-w645
Комментарий учителя