eolymp
bolt
Попробуйте наш новый интерфейс для отправки задач
Задачи

Банкомат

Банкомат

В некотором государстве в обращении находятся банкноты определённых номиналов. Национальный банк хочет, чтобы банкомат выдавал любую запрошенную сумму при помощи минимального числа банкнот, считая, что запас банкнот каждого номинала неограничен. Помогите Национальному банку решить задачу. \InputFile Первая строка содержит количество номиналов банкнот в обращении $n$ $(n ≤ 100)$. Вторая строка содержит $n$ различных натуральных чисел $x_1, x_2, ..., x_n$, не превосходящих $10^6$ - номиналы банкнот. Третья строка содержит сумму $s$ $(s ≤ 10^6)$, которую необходимо выдать. \OutputFile В первую строку выведите минимальное число слагаемых (или $-1$, если такого представления не существует). Во вторую строку выведите это представление в любом порядке.
Лимит времени 1 секунда
Лимит использования памяти 128 MiB
Входные данные #1
5
1 3 7 12 32
40
Выходные данные #1
3
32 7 1