Задача 5B. Космические связи

Автор: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
5 3
1 1
3 4
6 3
5 1
4 4
2

Разбор

Полный перебор + поиск компонент связности в графе за O(n2) (100 баллов) Первое, что сделаем — построим граф. С помощью полного перебора точек определим те, между которыми расстояние меньше или равно радиусу. Эти точки соединим ребром между собой. Применим алгоритм поиска компонент связности. Определим количество компонентов и выведем их количество.


0.099s 0.010s 13