23.07 Количество результатов выполнения программ
Ошибка.
Попробуйте повторить позже
Исполнитель преобразует число, записанное на экране. У исполнителя есть команды, которым присвоены номера:
1. Прибавить
2. Умножить на и прибавить
Первая команда увеличивает число на экране на вторая — увеличивает число в
раза и добавляет
Программа
для исполнителя — это последовательность команд.
Сколько различных результатов можно получить из исходного числа после выполнения программы, содержащей
ровно
команд?
Решение рекурсией
Мы определяем функцию f(start, com), где start — текущее число на экране, com — оставшееся количество команд.
1. Создаём пустое множество ans, чтобы хранить все уникальные результаты после выполнения всех команд.
2. В функции проверяем: если com == 0, значит, команд больше нет, добавляем текущее число start в ans.
3. Если команды ещё остались, рекурсивно вызываем функцию:
- сначала с командой «прибавь 2» (start + 2), уменьшив счётчик команд на 1;
- затем с командой «умножь на 2 и прибавь 1» (start * 2 + 1), также уменьшив счётчик команд на 1.
4. После рекурсивных вызовов множество ans будет содержать все уникальные результаты после выполнения 12 команд.
# Создаем пустое множество для хранения результатов ans = set() # Рекурсивная функция, которая перебирает все варианты применения команд def f(start, com): if com == 0: # Добавляем текущее число в множество результатов ans.add(start) return 0 # Применяем команду прибавить 2 f(start + 2, com - 1) # Применяем команду умножить на 2 и прибавить 1 f(start * 2 + 1, com - 1) # Запускаем функцию от исходного числа 6 с 12 командами f(6, 12) # Выводим количество различных результатов print(len(ans))
Решение динамикой
Мы создаём множество ans, в котором будем хранить все возможные числа после выполнения каждой команды.
1. Инициализируем множество ans числом .
2. Для каждой из 12 команд:
- создаём новое множество can_get, куда добавляем все результаты применения двух команд к каждому числу из текущего множества ans:
- число + 2;
- число * 2 + 1.
- присваиваем ans = can_get, чтобы перейти к следующему шагу.
3. После 12 итераций множество ans будет содержать все уникальные результаты, полученные после выполнения всех 12 команд.
# Инициализация множества с исходным числом ans = set() ans.add(6) # Проходим по 12 командам for cnt in range(12): can_get = set() # Для каждого числа применяем обе команды for i in ans: can_get.add(i + 2) can_get.add(i * 2 + 1) # Обновляем множество возможных чисел ans = can_get # Выводим количество различных результатов print(len(ans))
Специальные программы

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

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

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

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

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

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