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

23.06 Количество программ из A в B где траектория вычислений N команда

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

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

Задача 1#60490

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

1. Вычесть 3

2. Умножить на (-1)

Программа для исполнителя Отрицатель – это последовательность команд. Сколько различных неотрицательных результатов можно получить из исходного числа 82 в ходе исполнения программы, содержащей ровно 8 команд?

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

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

Мы используем рекурсивный способ решения, чтобы построить все возможные варианты выполнения 8 команд и посчитать, какие неотрицательные результаты получаются. Идея заключается в том, что мы создаем функцию f(n, c), где n — текущее число на доске, а c — количество уже выполненных команд.

1. Сначала мы создаем множество a, куда будем добавлять все полученные неотрицательные числа. Множество удобно, так как автоматически исключает повторения.

2. В функции f(n, c) реализуем проверку:

- если c == 8 (все команды выполнены), то проверяем знак числа:

      - если n >= 0, добавляем n в множество a.

- если c < 8, то выполняем оба возможных действия:

      - вычесть 3 (передаем n-3 в следующий вызов с увеличением счетчика команд на 1)

      - умножить на (-1) (передаем n*(-1) с увеличением счетчика команд на 1)

Важно, что проверка на количество команд и знак числа разделена, чтобы рекурсия не уходила бесконечно из-за отрицательных чисел.

3. Запускаем функцию с исходным числом 82 и нулевым счетчиком команд (f(82, 0)). После завершения всех рекурсивных вызовов в множестве a будут храниться все возможные неотрицательные результаты. Выводим это множество, чтобы получить ответ.

# Создаем пустое множество для хранения уникальных неотрицательных результатов
a = set()

# Определяем рекурсивную функцию f(n, c)
def f(n, c):
    # Проверяем, достигли ли мы 8 команд
    if c == 8:
        # Если число неотрицательное, добавляем его в множество
        if n >= 0:
            a.add(n)
    else:
        # Если команд меньше 8, выполняем оба возможных действия
        # 1) Вычитаем 3 и увеличиваем счетчик команд на 1
        f(n-3, c+1)
        # 2) Умножаем на (-1) и увеличиваем счетчик команд на 1
        f(n*(-1), c+1)

# Запускаем рекурсию с исходного числа 82 и 0 выполненных команд
f(82, 0)

# Выводим множество всех возможных неотрицательных результатов
print(a)

Ответ: 8

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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