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