#include<bits/stdc++.h>
#define P 2000
#define N 5005
#define M 400005
using namespace std;

int n,s,s2,t;
int cnt = 1;
int vis[N];
int dis[N];
int head[N];
long long cost;

struct edge{
    int to;
    int nxt;
    int val;
    int w;
}e[N<<1];

struct node{
    int x;
    int y;
    friend bool operator <(node a,node b)
    {
        if(a.x != b.x)
        {
            return a.x < b.x;
        }
        return a.y < b.y;
    }
}p[N];

void add(int x,int y,int z,int w)
{
    e[++cnt] = (edge){y,head[x],z,w};
    head[x] = cnt;
}
void addedge(int u,int v,int c,int w){
    printf("%d %d\n",u,v);
    add(u,v,c,w);add(v,u,0,-w);
}
bool spfa()
{
    memset(vis,0,sizeof(vis));
    memset(dis,0x3f,sizeof(dis));
    dis[s] = 0;
    vis[s] = 1;
    queue<int> q;
    q.push(s);
    while(!q.empty())
    {
        int u = q.front();
        q.pop();
        vis[u] = 0;
        for(int i=head[u];i;i=e[i].nxt)
        {
            int v = e[i].to;
            if(dis[v] < dis[u] + e[i].w && e[i].val)
            {
                dis[v] = dis[u] + e[i].w;
                if(!vis[v])
                {
                    q.push(v);
                    vis[v] = 1;
                }
            }
        }
    }
    return dis[t] != 0x3f3f3f3f;
}

int dfs(int u,int flow)
{
    if(u == t)
    {
        vis[t] = 1;
        return flow;
    }
    int used = 0;
    vis[u] = 1;
    for(int i=head[u];i;i=e[i].nxt)
    {
        int v = e[i].to;
        if((!vis[v] || v == t) && e[i].val != 0 && dis[v] == dis[u] + e[i].w)
        {
            int minflow = dfs(v,min(e[i].val,flow - used));
            if(minflow != 0)
            {
                 cost += e[i].w * minflow;
                 e[i].val -= minflow;
                 e[i^1].val += minflow;
                 used += minflow;
                 if(used == flow) break;
            }
        }
    }
    return used;
}

void costflow()
{
    while(spfa())
    {
        vis[t] = 1;
        while(vis[t])
        {
            memset(vis,0,sizeof(vis));
            dfs(s,1<<30);
        }
    }
}

int main()
{
    s = 0;
    t = 4001;
    s2 = 4002;
    cin>>n;
    for(int i=1;i<=n;i++)
    {
        cin>>p[i].x>>p[i].y;
    }
    sort(p+1,p+n+1);
    for(int i=1;i<=n;i++){
        printf("%d : %d,%d\n",i,p[i].x,p[i].y);
    }
    for(int i=1;i<=n;i++)
    {
        int maxy = 0,it=0;
        for(int j=i-1;j>=1;j--)
        {
            if(p[j].y > p[i].y || p[j].y < maxy)
            {
                continue;
            }
            maxy = max(maxy,p[j].y);
            it=j;
        }
        addedge(it,i,1,0);
    }

    costflow();
    cout<<cost<<endl;
    return 0;
}