Задача к ЕГЭ по информатике на тему «количество программ из a в b» №1

Исполнитель Краболов преобразует число на экране. У исполнителя есть три команды:

1. Прибавить 2

2. Умножить на 4

3. Прибавить 1

Программа для исполнителя — это последовательность команд.

Сколько существует программ, для которых при исходном числe 2  результатом является число 25  ?

Решение 1 (Рекурсия)

def f(st, fn):
    if st == fn:
        return 1
    if st > fn:
        return 0
    return f(st + 1, fn) + f(st + 2, fn) + f(st * 4, fn)
print(f(2, 25))

Решение 2 (Динамика)

a = [0] * 26
a[2] = 1
for i in range(3, 26):
    a[i] = a[i - 2] + a[i // 4] * (i % 4 == 0) + a[i - 1]
print(a[25])

Решение 3 (Динамика)

a = [0] * 150
a[2] = 1
for i in range(2, 25):
    a[i + 1] += a[i]
    a[i + 2] += a[i]
    a[i * 4] += a[i]
print(a[25])

Ответ: 49468
Оцените статью
Я решу все!