23.02 Количество программ из A в B (на убывание)
Ошибка.
Попробуйте повторить позже
Исполнитель Крабокрыл преобразует число на экране. У исполнителя есть 3 команды:
- Вычесть
- Поделить на
, если число кратно
- Поделить на
, если число кратно
Программа для исполнителя — это последовательность команд.
Сколько существует программ, для которых при исходном числe результатом является число
?
Решение 1 (Рекурсия)
def f(st, fn): if st == fn: return 1 if st < fn: return 0 x = f(st // 3, fn) * (st % 3 == 0) y = f(st // 2, fn) * (st % 2 == 0) z = f(st - 3, fn) return x + y + z print(f(30, 3))
Решение 2 (Динамика)
a = [0] * 31 a[30] = 1 for i in range(30, 1, - 1): a[i - 3] += a[i] a[i // 2] += a[i] * (i % 2 == 0) a[i // 3] += a[i] * (i % 3 == 0) print(a[3])
Решение 3 (Динамика)
a = [0] * 100 a[30] = 1 for i in range(29, 2, -1): a[i] = a[i + 3] + a[i * 3] + a[i * 2] print(a[3])
Специальные программы

Программа
лояльности v2.0
Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!
Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.

Бесплатное онлайн-обучение
Для школьников из приграничных территорий России, проживающих в ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Курской, Брянской областях и Крыму.

Налоговые вычеты
Узнай, как получить налоговый вычет при оплате обучения в «Школково».

Специальное предложение
для учителей
Бесплатный доступ к любому курсу подготовки к ЕГЭ, ОГЭ и олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!

Вернём деньги за курс
за твою сотку на ЕГЭ
Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!