#include #include #include #include #include #include #include #include #include #include #include #include #include #define repeat(i,n) for (int i = 0; (i) < int(n); ++(i)) #define repeat_from(i,m,n) for (int i = (m); (i) < int(n); ++(i)) #define repeat_reverse(i,n) for (int i = (n)-1; (i) >= 0; --(i)) #define repeat_from_reverse(i,m,n) for (int i = (n)-1; (i) >= int(m); --(i)) #define whole(f,x,...) ([&](decltype((x)) whole) { return (f)(begin(whole), end(whole), ## __VA_ARGS__); })(x) typedef long long ll; using namespace std; template void setmax(T & a, T const & b) { if (a < b) a = b; } template void setmin(T & a, T const & b) { if (b < a) a = b; } template auto vectors(X x, T a) { return vector(x, a); } template auto vectors(X x, Y y, Z z, Zs... zs) { auto cont = vectors(y, z, zs...); return vector(x, cont); } ll gcd(ll a, ll b) { while (a) { b %= a; swap(a, b); } return b; } ll lcm(ll a, ll b) { return (a * b) / gcd(a,b); } int main() { int n, k; cin >> n >> k; vector f_inv(n); whole(iota, f_inv, 0); while (k --) { int x, y; cin >> x >> y; -- x; -- y; swap(f_inv[x], f_inv[y]); } vector f(n); repeat (i,n) f[f_inv[i]] = i; vector cycle(n); repeat (i,n) { int j = f[i]; int k = 1; while (j != i) { j = f[j]; ++ k; } cycle[i] = k; } ll s = 1; for (int k : cycle) s = lcm(s, k); cout << s << endl; return 0; }