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

Банкомат

Банкомат

Лимит времени 1 секунда
Лимит использования памяти 128 MiB

В некотором государстве в обращении находятся банкноты определённых номиналов. Национальный банк хочет, чтобы банкомат выдавал любую запрошенную сумму при помощи минимального числа банкнот, считая, что запас банкнот каждого номинала неограничен.

Помогите Национальному банку решить задачу.

Входные данные

Первая строка содержит количество номиналов банкнот в обращении n(n ≤ 100). Вторая строка содержит n различных натуральных чисел x_1, x_2, ..., x_n, не превосходящих 10^6 - номиналы банкнот. Третья строка содержит сумму s(s ≤ 10^6), которую необходимо выдать.

Выходные данные

В первую строку выведите минимальное число слагаемых (или -1, если такого представления не существует). Во вторую строку выведите это представление в любом порядке.

Пример

Входные данные #1
5
1 3 7 12 32
40
Выходные данные #1
3
32 7 1