Олимпиадный тренинг

Задача . Кластеризация звёзд: радиус кластера и экстремальные звёзды


Задача

Темы:

Фрагмент звёздного неба спроецирован на плоскость. Учёный решил провести кластеризацию точек: разбить их на \(N\) непересекающихся непустых подмножеств так, чтобы точки каждого подмножества лежали внутри прямоугольника со сторонами длиной \(H\) и \(W\), причём прямоугольники между собой не пересекаются. Стороны прямоугольников не обязательно параллельны координатным осям.

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

Для каждой планеты дана характеристика: тип цвета, тип светимости и её размер в соответствии с таблицей.

ОбозначениеЦвет
Gбелый
Jзелёный
Lсиний
Nоранжевый
Yкрасный
Sголубой
Zжёлтый
ОбозначениеРазмер
Iбланкет
IIкарлик
IIIгигант
IVсверхгигант
Vмега-гигант
VIсупер-гигант
VIIпухляк

Полученные значения записаны в характеристике слитно: обозначение цвета, светимость (обозначается арабской цифрой) и размер планеты.

Будем называть центром кластера точку этого кластера, сумма расстояний от которой до всех остальных точек кластера минимальна. Для каждого кластера гарантируется единственность его центра. Расстояние между двумя точками на плоскости \(A(x_1,y_1)\) и \(B(x_2,y_2)\) вычисляется по формуле \(d=\sqrt{(x_2-x_1)^2+(y_2-y_1)^2}\).

В файле А хранятся данные о звёздах двух кластеров, где \(H=6{,}5\) и \(W=4{,}5\) для каждого кластера. В каждой строке записана информация о расположении на карте одной звезды: сначала координата \(x\), затем координата \(y\), а затем характеристика звезды. Значения даны в условных единицах. Известно, что количество точек не превышает 1100.

В файле Б хранятся данные о звёздах трёх кластеров, где \(H=6{,}5\) и \(W=5\) для каждого кластера. Известно, что количество точек не превышает 10 000. Структура хранения информации о звёздах в файле Б аналогична файлу А.

Для файла А определите координаты центра каждого кластера, затем найдите два числа: \(A_1\) — радиус кластера с наименьшим количеством точек (то есть максимальное расстояние от его центра до какой-либо точки того же кластера); и \(A_2\) — расстояние от центра того же кластера до ближайшего к нему зелёного гиганта (JIII), лежащего в этом кластере.

Для файла Б определите координаты центра каждого кластера, затем найдите два числа: \(B_1\) — минимальный радиус среди всех трёх кластеров; и \(B_2\) — максимальное расстояние между двумя оранжевыми пухляками (NVII), лежащими в кластере с максимальным радиусом.

В ответе запишите четыре числа через пробел: сначала целую часть абсолютного значения произведения \(A_1 \times 10\,000\), затем целую часть абсолютного значения произведения \(A_2 \times 10\,000\), затем — аналогично — для \(B_1\) и \(B_2\).


time 500 ms
memory 256 Mb
Правила оформления программ и список ошибок при автоматической проверке задач

Статистика успешных решений по компиляторам
Комментарий учителя