#include #define rep(i,n) for(int i=0;i<(n);i++) using namespace std; class permutation{ vector f; public: permutation(){} permutation(int n){ f.resize(n); iota(f.begin(),f.end(),0); } permutation(const vector& p):f(p){} permutation operator*(const permutation& p)const{ int n=f.size(); permutation res(n); rep(i,n) res.f[i]=f[p[i]]; return res; } int operator[](int i)const{ return f[i]; } int size()const{ return f.size(); } void swap(int i,int j){ std::swap(f[i],f[j]); } friend permutation inverse(const permutation& p){ int n=p.f.size(); permutation res(n); rep(i,n) res.f[p.f[i]]=i; return res; } }; int main(){ int n,k; scanf("%d%d",&n,&k); permutation p(n); rep(i,k){ int x; scanf("%d%*d",&x); x--; p.swap(x,x+1); } permutation q(n); for(int t=1;;t++){ q=q*p; bool ok=true; rep(i,n) if(q[i]!=i) ok=false; if(ok){ printf("%d\n",t); break; } } return 0; }