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

23.08 Прочие прототипы

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

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

Задача 1#84023

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

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

2. Умножь на 2

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

Сколько существует программ, для которых при исходном числе 5 результатом является число 299, если известно, что никакую команду нельзя выполнять более трёх раз подряд?

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

Решение рекурсией

Мы используем рекурсивный подход для подсчета количества программ, учитывая ограничение на повторение команд. Для этого мы определяем функцию f(a, b, c1, c2), где:

1. a  – текущее число на экране;

2. b  – целевое число, к которому нужно прийти;

3. c1  – количество последовательных применений команды 1 ("увеличь на 1");

4. c2  – количество последовательных применений команды 2 ("умножь на 2").

Алгоритм функции состоит из следующих шагов:

1. Проверяем, если текущее число a  превысило целевое число b  , значит дальнейшие действия не приведут к результату, возвращаем 0  .

2. Проверяем, если a  равно b  , то мы достигли цели, возвращаем 1  как количество одного успешного пути.

3. В остальных случаях создаём переменную s  , которая будет накапливать количество успешных программ.

4. Если команда 1 применялась меньше трёх раз подряд (c1 < 3  ), то вызываем функцию рекурсивно с аргументами (a+ 1,b,c1+ 1,0)  и добавляем результат к s  . Здесь мы увеличиваем a  на 1, увеличиваем счётчик c1  , а счётчик    c2  обнуляем, так как сменили команду.

5. Если команда 2 применялась меньше трёх раз подряд (c2 < 3  ), вызываем функцию рекурсивно с аргументами (a∗ 2,b,0,c2+ 1)  и добавляем результат к s  . Здесь мы умножаем a  на 2, обнуляем c1  , а c2  увеличиваем на 1.

6. Возвращаем сумму s  , которая содержит количество всех программ из текущего состояния.

Вызов функции f(5, 299) даёт искомое количество программ, начинающихся с числа 5 и приводящих к числу 299 с учётом ограничения на повторение команд.

# Определяем функцию f(a, b, c1=0, c2=0), которая считает количество программ
def f(a, b, c1 = 0, c2 = 0):
    # Если текущее число a больше целевого b, путь невозможен, возвращаем 0
    if a > b:
        return 0
    # Если текущее число a равно целевому b, найден один успешный путь, возвращаем 1
    if a == b:
        return 1
    else:
        # Создаём переменную s для накопления количества успешных программ
        s = 0
        # Если команда 1 применялась меньше 3 раз подряд, выполняем её и добавляем результат
        if c1 < 3:
            s += f(a + 1, b, c1 + 1, 0)
        # Если команда 2 применялась меньше 3 раз подряд, выполняем её и добавляем результат
        if c2 < 3:
            s += f(a * 2, b, 0, c2 + 1)
    # Возвращаем общее количество успешных программ из текущего состояния
    return s

# Вызываем функцию с начальным числом 5 и целевым 299 и выводим результат
print(f(5, 299))

Ответ: 26

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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