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

23.02 Количество программ из A в B (на убывание)

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

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

Задача 1#25996

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

  1. Вычесть 1
  2. Вычесть 3
  3. Взять остаток от деления на 4

Команда 3  выполняется только для чисел, больших, чем 4  . Программа для исполнителя — это последовательность команд. Сколько существует таких программ, которые исходное число 22  преобразуют в число 2  ?

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

Рекурсия:

Решение рекурсией

Идея рекурсивного решения заключается в создании функции, которая считает количество программ, преобразующих число x  в число y  . Функция работает следующим образом:

- Если текущее число x  стало меньше целевого y  , дальнейшие команды не приводят к решению, возвращаем 0  .

- Если x  равно y  , найден корректный путь, возвращаем 1  .

- В остальных случаях проверяем возможность применения команд:

1. Если x > 4  , можно применить команду 3 (взять остаток от деления на 4), а также команды 1 и 2 (вычесть 1 и вычесть 3).

2. Если x ≤ 4  , команда 3 недоступна, применяем только команды 1 и 2.

- Суммируем результаты рекурсивных вызовов для всех возможных применимых команд, чтобы получить общее количество программ.

# Определяем функцию f(x, y), которая считает количество программ
def f(x, y):
    # Если текущее число меньше целевого, путь невозможен
    if x < y:
        return 0
    # Если текущее число равно целевому, найден корректный путь
    elif x == y:
        return 1
    else:
        # Если текущее число больше 4, доступны все три команды
        if x > 4:
            return f(x - 1, y) + f(x - 3, y) + f(x % 4, y)
        else:
            # Иначе доступно только вычитание 1 и 3
            return f(x - 1, y) + f(x - 3, y)

# Запускаем функцию от исходного числа 22 до 2
print(f(22, 2))

Решение динамикой

Динамический подход заключается в построении массива, где индекс соответствует числу, а значение по индексу — количество программ, ведущих к этому числу, начиная с 22.

- Создаем массив длиной 23 (индексы от 0 до 22) и устанавливаем a[22] = 1  , так как существует один способ быть в начале.

- Проходим циклом по числам от 22 до 2 в обратном порядке (с помощью reversed(range(2,23))), чтобы суммировать пути для меньших чисел.

- Для каждого числа i  обновляем массив:

   - прибавляем к a[i − 1]  количество программ для i  , так как можно вычесть 1;

   - прибавляем к a[i − 3]  количество программ для i  , так как можно вычесть 3;

   - если i > 4  , прибавляем к a[i%4 ]  количество программ для i  , так как можно взять остаток от деления на 4.

- После завершения цикла a[2]  содержит количество программ, преобразующих 22 в 2.

# Создаем массив для хранения количества программ до числа 22
a = [0] * 23  # Индексы от 0 до 22
# Начальное число 22 имеет одну траекторию
a[22] = 1

# Перебираем числа от 22 до 2 в обратном порядке
for i in reversed(range(2, 23)):
    # Применяем команду "вычесть 1"
    a[i-1] += a[i]
    # Применяем команду "вычесть 3"
    a[i-3] += a[i]
    # Применяем команду "взять остаток от деления на 4", если i > 4
    if i > 4:
        a[i % 4] += a[i]

# Выводим количество программ для достижения числа 2
print(a[2])

Ответ: 1873

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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