#include #define ll long long #define INF 1000000005 #define MOD 1000000007 #define EPS 1e-10 #define rep(i,n) for(int i=0;i<(int)(n);++i) #define rrep(i,n) for(int i=(int)(n)-1;i>=0;--i) #define srep(i,s,t) for(int i=(int)(s);i<(int)(t);++i) #define each(a,b) for(auto& (a): (b)) #define all(v) (v).begin(),(v).end() #define len(v) (int)(v).size() #define zip(v) sort(all(v)),v.erase(unique(all(v)),v.end()) #define cmx(x,y) x=max(x,y) #define cmn(x,y) x=min(x,y) #define fi first #define se second #define pb push_back #define show(x) cout<<#x<<" = "<<(x)< P; typedef pair pll; typedef vector vi; typedef vector vvi; typedef vector vl; typedef vector vvl; typedef vector vd; typedef vector

vp; typedef vector vs; const int MAX_N = 100005; //long long型の素数判定には__int128を用いる const vector numset = {2,3,5,7,11,13,17,19,23,29,31,37}; // x^k (mod m) // ll modpow(ll x, ll k, ll m){ // ll res = 1; // while(k){ // if(k & 1){ // res = res * x % m; // } // k /= 2; // x = x * x % m; // } // return res; // } // long long型の素数判定の場合 ll modpow(__int128 x, ll k, ll m){ __int128 res = 1; while(k){ if(k & 1){ res = res * x % m; } k /= 2; x = x * x % m; } return res; } // check if n is prime bool check(ll n){ if(n < 2){ return false; } ll d = n - 1; ll s = 0; while(d % 2 == 0){ d /= 2; s++; } for(ll a : numset){ if(a == n){ return true; } if(modpow(a,d,n) != 1){ bool ok = true; for(ll r=0;r> n; rep(i, n){ ll x; cin >> x; cout << x << " " << check(x) << "\n"; } return 0; }