#include using namespace std; #define all(c) (c).begin(),(c).end() #define rrep(i,n) for(int i=(int)(n)-1;i>=0;i--) #define REP(i,m,n) for(int i=(int)(m);i<(int)(n);i++) #define rep(i,n) REP(i,0,n) #define iter(c) __typeof((c).begin()) #define tr(it,c) for(iter(c) it=(c).begin();it!=(c).end();it++) #define pb(a) push_back(a) #define pr(a) cout<<(a)<> #define F first #define S second #define ll long long bool check(int n,int m,int x,int y){return x>=0&&x=0&&y P; bool m[20001][20001]; double D(double x1, double y1, double x2, double y2) { return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2)); } int main() { int n; cin >> n; int ans=0; bool v[20001]; memset(v,0,sizeof(v)); memset(m,0,sizeof(m)); rep(i,n) { int x,y; cin >> x >> y; bool ck=true; REP(j,-20,21) { if(x+j<0 || x+j>20000 || !v[x+j]) continue; REP(k,-20,21) { if(y+k>=0 && y+k<20001 && m[x+j][y+k]==1 && D(x+j,y+k,x,y)<20) { ck=false; break; } } } if(ck) { m[x][y]=1; v[x]=1; ans++; } } cout << ans << endl; return 0; }