printРабочее место участника

printЗадачи

1709. Праздничный ужин

Ограничения: время – 2s/2s, память – 256MiB Ввод: input.txt или стандартный ввод Вывод: output.txt или стандартный вывод copy
Послать решение Blockly Посылки Темы Где Обсудить (0)

Рядом с офисом компании, в которой работает программист Джон, открылось новое кафе. Директор компании решил провести там новогодний ужин.
Меню праздничного новогоднего ужина в кафе состоит из `k` типов блюд. Для каждого типа блюда есть несколько вариантов на выбор. Всего есть `a_1` вариантов для первого типа блюда, `a_2` вариантов для второго типа блюда, и так далее, `a_k` вариантов для `k`-го типа блюда. Всего, таким образом, предлагается `a_1*a_2*…*a_k` различных заказов праздничного ужина.
Всего на ужине будут присутствовать `m` сотрудников компании. Каждый сотрудник должен заказать ровно один вариант блюда каждого типа на выбор. Таким образом, ужин каждого сотрудника будет состоять из `k` блюд. Для того чтобы ужин каждого сотрудника компании был уникален, администратор кафе придумал следующую схему. Сотрудники делают заказ ужина из меню один за другим. Каждый сотрудник выбирает `k` блюд, по одному варианту каждого типа. После выбора заказа из меню, сотрудник указывает один их типов блюд, и выбранный этим сотрудником вариант блюда этого типа больше не предлагается тем сотрудникам, которые делают заказ после него.
Каждый сотрудник компании запомнил, сколько возможных заказов ужина ему было предложено. Выяснилось, что директору, который выбирал первым, было предложено на выбор `n_1` = `a_1*a_2*…*a_k` заказов. Тому, кто выбирал вторым, досталось лишь `n_2 < n_1` заказов, поскольку один из вариантов одного из типов блюд уже не был доступен, и так далее. Джону, который выбирал последним, был предложен выбор лишь из `n_m` заказов. Джон заинтересовался, а какое количество вариантов каждого типа блюд было на выбор у директора компании.
Требуется написать программу, которая по заданным числам `k`, `m` и `n_1,\ n_2,\ …,\ n_m` выяснит, какое количество вариантов каждого типа блюд изначально предлагалось на выбор.
Формат входного файла
Первая строка входного файла содержит два целых числа `k` и `m`, разделенных ровно одним пробелом (`1 ≤ k ≤ 20`, `2 ≤ m ≤ 100`).
Вторая строка содержит `m` чисел: `n_1,\ n_2,\ …,\ n_m` (для всех `i` от 1 до `m` выполняется неравенство `1 ≤ "ni" ≤ 10^9`).
Формат выходного файла
Выходной файл должен содержать `k` чисел: `a_1,\ a_2,\ …,\ a_k`. Если возможных вариантов решения поставленной задачи несколько, требуется вывести любой. Соседние числа должны быть разделены ровно одним пробелом. Гарантируется, что хотя бы одно решение существует.

Пример ввода

3 3
12 8 4

Пример вывода

3 2 2
Пояснения к примеру
События в примере могли развиваться, например, следующим образом.
Исходно количество заказов ужина было равно `3*2*2=12`. Директор, выбрав свой заказ, указал блюдо первого типа, поэтому второму сотруднику осталось лишь два варианта блюда первого типа. Количество заказов для него сократилось до `2*2*2 = 8`. Он также указал на свое блюдо первого типа, и Джон уже мог выбирать лишь из `1*2*2 = 4` заказов ужина.
Источник: региональный этап Всероссийской олимпиады по информатике 2011/2012, http://neerc.ifmo.ru/school/
loading