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

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

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

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

Задача 1#61639

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

1. Прибавить 1.

2. Отнять 2.

3. Умножить на 3.

Первая команда увеличивает число на 1, вторая уменьшает число на 2, третья – умножает на 3. Сколько различных результатов можно получить из исходного числа 2 после выполнения программы, содержащей 20 команд, если известно, что запрещено повторять команду, сделанную на предыдущем шаге.

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

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

1. Создаём рекурсивную функцию, которая принимает:

- текущее число a  ,

- счётчик команд k  ,

- номер последней выполненной команды last  (чтобы не повторять её на следующем шаге).

2. Если выполнено 20 команд (k == 20  ), добавляем текущее число a  в множество s  .

3. Если количество команд меньше 20:

- Проверяем последнюю выполненную команду last  .

- Для каждой команды, не совпадающей с предыдущей, вызываем рекурсивно функцию с увеличенным счётчиком команд и обновлённым числом a  .

4. Множество s  хранит все уникальные результаты после 20 команд.

5. Вызов функции начинается с числа 2 и с параметром last = 0  , что означает отсутствие предыдущей команды.

from functools import lru_cache
@lru_cache(None)

# Рекурсивная функция для подсчета уникальных результатов
def f(a, k, last = 0):
    # a - текущее число, k - количество выполненных команд, last - последняя команда
    if k == 20:
        s.add(a)  # достигли 20 команд, добавляем результат
    if k < 20:
        # Если предыдущей команды не было, можно применять любую
        if last == 0:
            f(a + 1, k + 1, 1)
            f(a - 2, k + 1, 2)
            f(a * 3, k + 1, 3)
        # Если предыдущая команда была 1, применяем только 2 или 3
        if last == 1:
            f(a - 2, k + 1, 2)
            f(a * 3, k + 1, 3)
        # Если предыдущая команда была 2, применяем только 1 или 3
        if last == 2:
            f(a + 1, k + 1, 1)
            f(a * 3, k + 1, 3)
        # Если предыдущая команда была 3, применяем только 1 или 2
        if last == 3:
            f(a + 1, k + 1, 1)
            f(a - 2, k + 1, 2)

# Множество для хранения всех уникальных результатов
s = set()
# Запуск функции с исходного числа 2
f(2, 0)
# Количество различных результатов программы
print(len(s))

Ответ: 35093

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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