23.07 Количество результатов выполнения программ
Ошибка.
Попробуйте повторить позже
Исполнитель Сотка преобразует число, записанное на экране. У исполнителя есть три команды, которым присвоены номера:
1. Прибавить 1.
2. Отнять 2.
3. Умножить на 3.
Первая команда увеличивает число на 1, вторая уменьшает число на 2, третья – умножает на 3. Сколько различных результатов можно получить из исходного числа 2 после выполнения программы, содержащей 20 команд, если известно, что запрещено повторять команду, сделанную на предыдущем шаге.
Рекурсивное решение:
1. Создаём рекурсивную функцию, которая принимает:
- текущее число ,
- счётчик команд ,
- номер последней выполненной команды (чтобы не повторять её на следующем шаге).
2. Если выполнено 20 команд (), добавляем текущее число
в множество
.
3. Если количество команд меньше 20:
- Проверяем последнюю выполненную команду .
- Для каждой команды, не совпадающей с предыдущей, вызываем рекурсивно функцию с увеличенным счётчиком
команд и обновлённым числом .
4. Множество хранит все уникальные результаты после 20 команд.
5. Вызов функции начинается с числа 2 и с параметром , что означает отсутствие предыдущей
команды.
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))
Специальные программы

Программа
лояльности v2.0
Приглашай друзей в Школково и получай вознаграждение до 10%!

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

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

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

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

Вернём деньги за курс
за твою сотку на ЕГЭ
Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!