23.07 Количество результатов выполнения программ
Ошибка.
Попробуйте повторить позже
Исполнитель Щелчок преобразует число на экране. У исполнителя есть три команды:
1. Прибавить 1
2. Умножить на 2
3. Прибавить 4
Программа для исполнителя — это последовательность команд.
Сколько существует различных результатов выполнения программ, содержащих 8 команд и начинающих свою работу из 2.
Решение 1 (Рекурсия)
def f(st, count, end_count): global A # объявляем А глобальной переменной, # чтобы добавлять туда новые элементы внутри функции if count == end_count: A.add(st) else: f(st + 1, count + 1, end_count) f(st * 2, count + 1, end_count) f(st + 4, count + 1, end_count) A = set() # Лучший вариант для данной задачи, так как в множестве # не повторяются элементы f(2, 0, 8) print(len(A))
Решение 2 (Динамика)
ans = set() ans.add(2) for operations in range(8): can_get = set() for i in ans: can_get.add(i + 1) can_get.add(i * 2) can_get.add(i + 4) ans = can_get print(len(ans))
Специальные программы
Программа
лояльности v2.0
Приглашай друзей в Школково и получай вознаграждение до 10%!
Крути рулетку
и выигрывай призы!
Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.
Бесплатное онлайн-обучение
Для школьников из приграничных территорий России, проживающих в ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Курской, Брянской областях и Крыму.
Налоговые вычеты
Узнай, как получить налоговый вычет при оплате обучения в «Школково».
Специальное предложение
для учителей
Бесплатный доступ к любому курсу подготовки к ЕГЭ, ОГЭ и олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!
Вернём деньги за курс
за твою сотку на ЕГЭ
Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!