Задача #3203

Анализ данных

Уровень ЕГЭ

Фрагмент звёздного неба спроецирован на плоскость с декартовой системой координат. Учёный решил провести кластеризацию полученных точек, являющихся изображениями звёзд, то есть разбить их множество на N непересекающихся непустых подмножеств (кластеров), таких что точки каждого подмножества лежат внутри квадрата со стороной длины H, причём эти квадраты между собой не пересекаются. Стороны квадратов не обязательно параллельны координатным осям. Гарантируется, что такое разбиение существует и единственно для заданных размеров квадратов.
Будем называть антицентром кластера точку этого кластера, сумма расстояний от которой до всех остальных точек кластера максимальна. Для каждого кластера гарантируется единственность его антицентра. Расстояние между двумя точками на плоскости A(x1,y1) и B(x2,y2) вычисляется по формуле: d(A,B)=(x2x1)2+(y2y1)2
В файле A хранятся данные о звёздах двух кластеров, где H=8 для каждого кластера. В каждой строке записана информация о расположении на карте одной звезды: сначала координата x, затем координата y. Значения даны в условных единицах. Известно, что количество звёзд не превышает 1000.
В файле B хранятся данные о звёздах трёх кластеров, где H=6 для каждого кластера. Известно, что количество звёзд не превышает 10 000. Структура хранения информации о звездах в файле B аналогична файлу А.
Для каждого файла определите координаты антицентра каждого кластера, затем вычислите два числа: Px – абсциссу антицентра кластера с наименьшим числом точек, и Py – ординату антицентра кластера с наибольшим числом точек.
В ответе запишите четыре числа: в первой строке сначала целую часть произведения Px×10000, затем целую часть произведения Py×10000 для файла А, во второй строке – аналогичные данные для файла B.
Возможные данные одного из файлов иллюстрированы графиком.
Внимание! График приведён в иллюстративных целях для произвольных значений, не имеющих отношения к заданию.
Для выполнения задания используйте данные из прилагаемого файла.

Ответ
Вопрос A
Вопрос B
Войдите, чтобы история ответов и статистика сохранялись.
Решение Нажми, чтобы открыть

Ответ

Вопрос A
1663
61127
Вопрос B
147474
61934
data = []
for s in open('27_B.txt'):
x,y = [float(d) for d in s.split()]
data.append([x,y])

from math import *

clusters = []
while data:
cl = [data.pop()]
for p in cl:
sosed = [p1 for p1 in data if dist(p,p1)<1]
for p1 in sosed:
cl.append(p1)
data.remove(p1)
clusters.append(cl)

print([len(cl) for cl in clusters])

def acentr(cl):
m = []
for p in cl:
s = sum(dist(p,p1) for p1 in cl)
m.append([s,p])
return max(m)[1]

mn = min(clusters, key=len)
mx = max(clusters, key=len)
px = acentr(mn)[0]
py = acentr(mx)[1]
print(int(px*10000), int(py*10000))
Быстрый переход
Перейти к задаче