Задача #1531
Количество программ
(М. Ишимов) Исполнитель преобразует число на экране.
У исполнителя есть две команды, которые обозначены латинскими буквами:
A. Вычесть 3
B. Найти целую часть от деления на 2
Программа для исполнителя – это последовательность команд.
Сколько существует программ, для которых при исходном числе 28 результатом является число 3?
Войдите, чтобы история ответов и статистика сохранялись.
Решение
Ответ
10
def f(s, e):
if s <= e: return s == e
return f(s - 3, e) + f(s // 2, e)
print(f(28, 3))