23.02 Количество программ из A в B (на убывание)
Ошибка.
Попробуйте повторить позже
Исполнитель преобразует число, записанное на экране. У исполнителя есть три команды, которым присвоены номера:
1. Вычесть 1
2. Вычесть 3
3. Взять остаток от деления на 4
Команда 3 выполняется только для чисел, больших, чем 4. Программа для исполнителя — это последовательность команд.
Сколько существует таких программ, которые исходное число 22 преобразуют в число 2?
Рекурсия:
def f(x, y): if x < y: return 0 elif x == y: return 1 else: if x > 4: return f(x - 1, y) + f(x - 3, y) + f(x % 4, y) else: return f(x - 1, y) + f(x - 3, y) print(f(22, 2))
Динамика:
a = [0] * 25 a[22] = 1 for i in reversed(range(2, 22)): a[i] = a[i+1] + a[i+3] if i < 4: for j in range(i + 4, 23, 4): a[i] += a[j] print(a[2])
Специальные программы

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

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

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

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

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

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