Имеется X монет достоинствами N1, N2, N3, ... , Nm рублей. Мальчик хочет узнать K - количество способов выбрать из этих монет Y рублей. Монеты одинакового достоинства считаются одинаковыми.

23 Авг 2019 в 19:42
182 +1
0
Ответы
1

Для решения этой задачи можно воспользоваться динамическим программированием.

Создадим массив dp[], где dp[i] будет содержать количество способов выбрать сумму i рублей с использованием заданных монет.

Изначально заполним массив dp[] нулями, кроме dp[0], который равен 1 (так как один способ выбрать 0 рублей - не выбирать ни одной монеты).

Далее пройдемся по всем монетам. Для каждой монеты пройдемся по всем рублям от этой монеты до требуемой суммы Y и прибавим к dp[j] количество способов выбрать сумму j-этой монетой.

После обработки всех монет в dp[Y] будет содержаться количество способов выбрать сумму Y рублей с использованием заданных монет. Количество способов Y рублей равно dp[Y].

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

20 Апр в 13:00
Не можешь разобраться в этой теме?
Обратись за помощью к экспертам
Название заказа не должно быть пустым
Введите email
Бесплатные доработки
Гарантированные бесплатные доработки
Быстрое выполнение
Быстрое выполнение от 2 часов
Проверка работы
Проверка работы на плагиат
Интересные статьи из справочника
Поможем написать учебную работу
Название заказа не должно быть пустым
Введите email
Доверьте свою работу экспертам
Разместите заказ
Наша система отправит ваш заказ на оценку 84 134 авторам
Первые отклики появятся уже в течение 10 минут
Прямой эфир