Тема 23. Оператор присваивания и ветвления

23.07 Количество результатов выполнения программ

Вспоминай формулы по каждой теме
Решай новые задачи каждый день
Вдумчиво разбирай решения
ШКОЛКОВО.
Готовиться с нами - ЛЕГКО!
Подтемы раздела оператор присваивания и ветвления
Решаем задачу:

Ошибка.
Попробуйте повторить позже

Задача 1#84016

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

1. Увеличь на 1

2. Умножь на 2

3. Умножь на 3

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

Сколько существует программ, для которых при исходном числе 8 результатом является число 123, если известно, что после второй команды обязательно должна идти третья?

Показать ответ и решение

Рекурсивное решение:

1. Введём рекурсивную функцию f(a,b,c)  , где:

- a  — текущее число на экране,

- b  — целевое число,

- c  — номер команды, выполненной на предыдущем шаге.

2. Если a > b  , возвращаем 0 (превышено целевое число).

3. Если a = b  , возвращаем 1 (найдена программа, ведущая к цели).

4. Если предыдущая команда была вторая (c = 2  ), то следующий шаг обязательно третья команда:

f(a∗3,b,3)

5. В остальных случаях можно применить любую команду:

- a + 1  (команда 1)

- a ∗2  (команда 2)

- a ∗3  (команда 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))

Ответ: 111

Специальные программы

Все специальные программы

Программа
лояльности v2.0

Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!

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

Бесплатное онлайн-обучение

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

Налоговые вычеты

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

Специальное предложение
для учителей

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

Вернём деньги за курс
за твою сотку на ЕГЭ

Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!

cyberpunkMouse
cyberpunkMouse
Рулетка
Вы можете получить скидку в рулетке!