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

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

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

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

Задача 1#30484

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

1. Прибавить квадрат числа

2. Прибавить целую часть квадратного корня числа, если корень возможно извлечь

3. Вычесть 12

Программа для исполнителя — это последовательность команд.

Сколько существует различных результатов выполнения программ, содержащих 5 команд и начинающих свою работу из 23. При этом исполнитель не может совершать ходы, которые приводят его в числа кратные 5. Например, из числа 7 можно попасть только в 9 и 56.

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

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

Мы будем использовать рекурсию для перебора всех возможных траекторий команд, учитывая ограничения:

1. Создаём пустое множество A для хранения уникальных результатов.

2. Определяем рекурсивную функцию f(st, count, end_count), где st — текущее число, count — количество применённых команд, end_count — общее количество команд.

3. Если count == end_count, добавляем текущее число st в множество A, так как достигли конца программы.

4. Если команд осталось, проверяем каждую команду и условие кратности 5:

- Если (st + st**2) % 5 != 0, применяем команду прибавить квадрат числа, увеличиваем count на 1.

- Если (st - 12) % 5 != 0, применяем команду вычесть 12, увеличиваем count на 1.

- Если st >= 0 и (st + int(st**0.5)) % 5 != 0, применяем команду прибавить целую часть квадратного корня числа, увеличиваем count на 1.

5. После всех рекурсивных вызовов множество A содержит все уникальные результаты.

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

# Рекурсивная функция для перебора всех последовательностей команд
def f(st, count, end_count):
    if count == end_count:
        # Добавляем текущее число в множество уникальных результатов
        A.add(st)
    else:
        # Команда прибавить квадрат числа
        if (st + st ** 2) % 5 != 0:
            f(st + st ** 2, count + 1, end_count)
        # Команда вычесть 12
        if (st - 12) % 5 != 0:
            f(st - 12, count + 1, end_count)
        # Команда прибавить целую часть квадратного корня
        if st >= 0:
            if (st + int(st ** 0.5)) % 5 != 0:
                f(st + int(st ** 0.5), count + 1, end_count)

# Запускаем функцию с исходным числом 23 и 5 командами
f(23, 0, 5)

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

Решение через динамику

1. Создаём множество ans с исходным числом 23.

2. Для каждой из 5 команд выполняем следующие шаги:

- Создаём новое множество can_get.

- Для каждого числа i в ans:

* Если (i + i**2) % 5 != 0, добавляем i + i**2 в can_get.

* Если (i - 12) % 5 != 0, добавляем i - 12.

* Если i >= 0 и (i + int(i**0.5)) % 5 != 0, добавляем i + int(i**0.5).

- После обработки всех чисел обновляем ans = can_get.

3. В конце размер множества ans даёт количество уникальных результатов.

# Множество для хранения текущих результатов
ans = set()
ans.add(23)

# Последовательно применяем 5 команд
for operations in range(5):
    can_get = set()
    for i in ans:
        if (i + i ** 2) % 5 != 0:
            can_get.add(i + i ** 2)
        if (i - 12) % 5 != 0:
            can_get.add(i - 12)
        if i >= 0:
            if (i + int(i ** 0.5)) % 5 != 0:
                can_get.add(i + int(i ** 0.5))
    ans = can_get

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

Ответ: 57

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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