23.07 Количество результатов выполнения программ
Ошибка.
Попробуйте повторить позже
Исполнитель преобразует число на экране. У исполнителя есть три команды, которым присвоены номера:
1. Увеличь на 1
2. Умножь на 2
3. Умножь на 3
Программа для исполнителя – это последовательность команд.
Сколько существует программ, для которых при исходном числе 8 результатом является число 123, если известно, что после второй команды обязательно должна идти третья?
Рекурсивное решение:
1. Введём рекурсивную функцию , где:
- — текущее число на экране,
- — целевое число,
- — номер команды, выполненной на предыдущем шаге.
2. Если , возвращаем 0 (превышено целевое число).
3. Если , возвращаем 1 (найдена программа, ведущая к цели).
4. Если предыдущая команда была вторая (), то следующий шаг обязательно третья команда:
5. В остальных случаях можно применить любую команду:
- (команда 1)
- (команда 2)
- (команда 3)
def f(a, b, c=0): # a - текущее число на экране # b - целевое число # c - номер команды, выполненной на предыдущем шаге (0 означает, что команды ещё не было) if a > b: # Если текущее число больше целевого, пути нет return 0 if a == b: # Если текущее число равно целевому, найден один путь return 1 if c == 2: # Если предыдущая команда была 2 (умножить на 2), # следующая обязательно должна быть команда 3 (умножить на 3) return f(a * 3, b, 3) # В остальных случаях можно применить любую из трёх команд: # 1. прибавить 1 # 2. умножить на 2 # 3. умножить на 3 return f(a + 1, b, 1) + f(a * 2, b, 2) + f(a * 3, b, 3) # Запускаем функцию с исходным числом 8, целевым числом 123 print(f(8, 123))
Специальные программы

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

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

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

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

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

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