Автор: | ONTI | Ограничение времени: | 1 сек | |
Входной файл: | Стандартный вход | Ограничение памяти: | 256 Мб | |
Выходной файл: | Стандартный выход | |||
Максимальный балл: | 100 |
Ученые решили изучить состояние межпланетных отношений. В первую очередь им нужно посчитать количество планетарных коалиций (групп планет). Они имеют информацию об n планетах во Вселенной. У каждой планеты есть координаты в двухмерном пространстве x и y. Планета состоит в некоторой коалиции, если она попадает в радиус r хотя бы одной планеты из этой коалиции. Они просят Вас написать программу, которая определит количество коалиций во Вселенной.
В первой строке записано два целых числа n (1 ≤ n ≤ 103) и r (1 ≤ r ≤ 106) — количество планет, которые известны ученым, и радиус взаимодействия планет.
В следующих n строках записано по два числа x и y ( − 106 ≤ x, y ≤ 106) — координаты планет.
Выведите одно целое число — количество коалиций, образованных всеми известными планетами.
Методика проверки Программа проверяется на 50 тестах. Прохождение каждого теста оценивается в 2 балла. Тест из примера к задаче при проверке не используется.
№ | Стандартный вход | Стандартный выход |
---|---|---|
1 |
|
|
Полный перебор + поиск компонент связности в графе за O(n2) (100 баллов) Первое, что сделаем — построим граф. С помощью полного перебора точек определим те, между которыми расстояние меньше или равно радиусу. Эти точки соединим ребром между собой. Применим алгоритм поиска компонент связности. Определим количество компонентов и выведем их количество.