#include #include #include #include #include #include #include #include #include #include #include #include #include #ifndef ONLINE_JUDGE //POJ # include # include # define mkt make_tuple # define empb emplace_back #endif #ifdef _LOCAL # include "for_local.h" #endif using namespace std; typedef unsigned int uint; typedef unsigned long long ull; #define repi(_I, _B, _E) for(int _I = (_B); (_I) < (_E); ++ (_I)) #define rep(_I, _N) for(int _I = 0; (_I) < (_N); ++ (_I)) #define mkp make_pair #define all(_X) (_X).begin(), (_X).end() #define scani(_V) std::scanf("%d", &_V) #define printi(_V) std::printf("%d", static_cast(_V)) #include template T selfprod(T const& x, T const& y) { return x * x + y * y; } int const B = 10; vector>> board(20000 / B); bool conflict(int i, int x, int y) { if ( !(0 <= i && i < board.size()) ) return false; auto& b = board[i]; auto lb = lower_bound(all(b), mkp(x - 20, y - 20)); auto ub = upper_bound(all(b), mkp(x + 20, y + 20)); for ( ; lb != ub; ++lb ) { auto& p = *lb; if ( selfprod(x - p.first, y - p.second) < 400 ) return true; } return false; } bool conflict(int x, int y) { int yl = (y - 20) / B; int yr = min(board.size(), (y + 20 + B - 1) / B); for ( int i = yl; i < yr; ++i ) { if ( conflict(i, x, y) ) return true; } return false; } signed main() { int n; scanf("%d", &n); int k = 0; rep(i, n) { int x, y; scanf("%d %d", &x, &y); if ( !conflict(x, y) ) { board[y/ B].emplace(lower_bound(all(board[y/B]), mkp(x, y)), mkp(x, y)); ++k; } } printf("%d\n", k); return 0; }