#include<bits/stdc++.h>
using namespace std;
struct Node{
int zx,cv;
};
int cmp(Node x,Node y)
{
return x.zx>y.zx;
}
Node a[1000000];
int main()
{
int n,m;
cin>>n>>m;
int sum=0;
for(int i=1;i<=m;i++)
{
cin>>a[i].zx>>a[i].cv;
}
sort(a+1,a+n+1,cmp);
int aa=0,ss=0;
for(int i=1;i<=n;i++)
{
if(a[i].zx>=ss)
{
aa++;
ss=a[i].cv;
}
}
cout<<aa;
}