#pragma GCC optimize("O3")
#include <bits/stdc++.h>
using namespace std;
#define boost ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0)
#define rando mt19937 rng(chrono::steady_clock::now().time_since_epoch().count())
#define fi first
#define se second
#define debug(x) cerr << " - " << #x << ": " << x << endl;
#define debugs(x, y) cerr << " - " << #x << ": " << x << " " << #y << ": " << y << endl;
#define debugii(x) cerr << " - " << #x << ": " << x.fi<<","<<x.se << endl;
#define sep() cerr << "--------------------" << endl;
#define all(x) (x).begin(),(x).end()
#define sz(x) (ll)x.size()
#define ld long double
#define ll long long
#define int ll
#define ii pair<int,int>
#define v vector<int>
#define vii vector<ii>
#define vv vector<vector<int> >
#define mp make_pair
#define INF 1e14
#define pb push_back
#define EPS 1e-9
const int MOD = 1000000007; // 998244353
int xs[2002],ys[2002];
int32_t main(){
boost;
//freopen(".in","r",stdin);
int n;
cin>>n;
v vec;
for (int i = 0; i < n; ++i){
cin>>xs[i]>>ys[i];
vec.pb(i);
}
int ans=0;
while(!vec.empty()){
ans++;
int max_x=-INF,max_y=-INF,min_x=INF,min_y=INF;
for(auto it:vec){
max_x=max(max_x,xs[it]);
max_y=max(max_y,ys[it]);
min_x=min(min_x,xs[it]);
min_y=min(min_y,ys[it]);
}
v n_vec;
for(auto it:vec){
if((xs[it]==min_x||xs[it]==max_x)&&(ys[it]<=max_y)&&(ys[it]>=min_y))continue;
if((ys[it]==min_y||ys[it]==max_y)&&(xs[it]<=max_x)&&(xs[it]>=min_x))continue;
n_vec.pb(it);
}
vec=n_vec;
}
cout<<ans;
return 0;
}
//long long
//array bounds
//special cases
//binary search
I3ByYWdtYSBHQ0Mgb3B0aW1pemUoIk8zIikKI2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CiNkZWZpbmUgYm9vc3QgaW9zX2Jhc2U6OnN5bmNfd2l0aF9zdGRpbyhmYWxzZSk7IGNpbi50aWUoMCk7IGNvdXQudGllKDApCiNkZWZpbmUgcmFuZG8gbXQxOTkzNyBybmcoY2hyb25vOjpzdGVhZHlfY2xvY2s6Om5vdygpLnRpbWVfc2luY2VfZXBvY2goKS5jb3VudCgpKQojZGVmaW5lIGZpIGZpcnN0CiNkZWZpbmUgc2Ugc2Vjb25kCiNkZWZpbmUgZGVidWcoeCkgY2VyciA8PCAiIC0gIiA8PCAjeCA8PCAiOiAiIDw8IHggPDwgZW5kbDsKI2RlZmluZSBkZWJ1Z3MoeCwgeSkgY2VyciA8PCAiIC0gIiA8PCAjeCA8PCAiOiAiIDw8IHggPDwgIiAiIDw8ICN5IDw8ICI6ICIgPDwgeSA8PCBlbmRsOwojZGVmaW5lIGRlYnVnaWkoeCkgY2VyciA8PCAiIC0gIiA8PCAjeCA8PCAiOiAiIDw8IHguZmk8PCIsIjw8eC5zZSA8PCBlbmRsOwojZGVmaW5lIHNlcCgpIGNlcnIgPDwgIi0tLS0tLS0tLS0tLS0tLS0tLS0tIiA8PCBlbmRsOwojZGVmaW5lIGFsbCh4KSAoeCkuYmVnaW4oKSwoeCkuZW5kKCkKI2RlZmluZSBzeih4KSAobGwpeC5zaXplKCkKI2RlZmluZSBsZCBsb25nIGRvdWJsZQojZGVmaW5lIGxsIGxvbmcgbG9uZwojZGVmaW5lIGludCBsbAojZGVmaW5lIGlpIHBhaXI8aW50LGludD4KI2RlZmluZSB2IHZlY3RvcjxpbnQ+CiNkZWZpbmUgdmlpIHZlY3RvcjxpaT4KI2RlZmluZSB2diB2ZWN0b3I8dmVjdG9yPGludD4gPgojZGVmaW5lIG1wIG1ha2VfcGFpcgojZGVmaW5lIElORiAxZTE0CiNkZWZpbmUgcGIgcHVzaF9iYWNrCiNkZWZpbmUgRVBTIDFlLTkKY29uc3QgaW50IE1PRCA9IDEwMDAwMDAwMDc7IC8vIDk5ODI0NDM1MwppbnQgeHNbMjAwMl0seXNbMjAwMl07CmludDMyX3QgbWFpbigpewoJYm9vc3Q7CgkvL2ZyZW9wZW4oIi5pbiIsInIiLHN0ZGluKTsKCWludCBuOwoJY2luPj5uOwoJdiB2ZWM7Cglmb3IgKGludCBpID0gMDsgaSA8IG47ICsraSl7CgkJY2luPj54c1tpXT4+eXNbaV07CgkJdmVjLnBiKGkpOwoJfQoJaW50IGFucz0wOwoJd2hpbGUoIXZlYy5lbXB0eSgpKXsKCQlhbnMrKzsKCQlpbnQgbWF4X3g9LUlORixtYXhfeT0tSU5GLG1pbl94PUlORixtaW5feT1JTkY7CgkJZm9yKGF1dG8gaXQ6dmVjKXsKCQkJbWF4X3g9bWF4KG1heF94LHhzW2l0XSk7CgkJCW1heF95PW1heChtYXhfeSx5c1tpdF0pOwoJCQltaW5feD1taW4obWluX3gseHNbaXRdKTsKCQkJbWluX3k9bWluKG1pbl95LHlzW2l0XSk7CgkJfQoJCXYgbl92ZWM7CgkJZm9yKGF1dG8gaXQ6dmVjKXsKCQkJaWYoKHhzW2l0XT09bWluX3h8fHhzW2l0XT09bWF4X3gpJiYoeXNbaXRdPD1tYXhfeSkmJih5c1tpdF0+PW1pbl95KSljb250aW51ZTsKCQkJaWYoKHlzW2l0XT09bWluX3l8fHlzW2l0XT09bWF4X3kpJiYoeHNbaXRdPD1tYXhfeCkmJih4c1tpdF0+PW1pbl94KSljb250aW51ZTsKCQkJbl92ZWMucGIoaXQpOwoJCX0KCQl2ZWM9bl92ZWM7Cgl9Cgljb3V0PDxhbnM7CglyZXR1cm4gMDsKfQovL2xvbmcgbG9uZwovL2FycmF5IGJvdW5kcwovL3NwZWNpYWwgY2FzZXMKLy9iaW5hcnkgc2VhcmNo