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

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

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

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

Задача 1#84017

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

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

2. Уменьши на 4

3. Раздели на 2

Причём команду 3 можно применять только для чётных чисел. Программа для исполнителя – это последовательность команд.

Сколько различных натуральных результатов можно получить при исходном числе 16 в ходе исполнения программы, содержащей ровно 10 команд, если известно, что нельзя повторять третью команду, если она была использована на предыдущем шаге.

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

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

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

1. Если количество совершённых команд k равно 10, проверяем, является ли текущее число a натуральным (больше или равно 1). Если да, добавляем его в множество s для хранения различных результатов. Затем возвращаемся, чтобы исследовать другие варианты.

2. Вызываем рекурсивно функцию для каждой команды:

- Команда 1: прибавляем 8 к текущему числу и увеличиваем счётчик команд на 1, помечая предыдущую команду как 1.

- Команда 2: вычитаем 4, увеличиваем счётчик команд на 1, помечаем предыдущую команду как 2.

- Команда 3: делим на 2 только если текущее число чётное и предыдущая команда не была 3, увеличиваем счётчик команд на 1 и помечаем предыдущую команду как 3.

Таким образом, функция перебирает все возможные комбинации команд, учитывая ограничения, и собирает все различные натуральные числа, которые могут получиться после 10 команд.

# Множество для хранения всех различных результатов
s = set()

# Рекурсивная функция для перебора всех траекторий
def f(a, c = 0, k = 0):
    # Если выполнено ровно 10 команд
    if k == 10:
        # Если число натуральное, добавляем в множество результатов
        if a >= 1:
            s.add(a)
        return 0
    # Применяем команду 1: прибавляем 8
    f(a + 8, 1, k + 1)
    # Применяем команду 2: вычитаем 4
    f(a - 4, 2, k + 1)
    # Применяем команду 3: делим на 2, если число четное и команда не повторяется
    if c != 3 and a % 2 == 0:
        f(a // 2, 3, k + 1)

# Запускаем рекурсивный перебор с начального числа 16
f(16)

# Выводим количество различных натуральных результатов
print(len(s))

Ответ: 67

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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