#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; typedef long long int ll; typedef pair P; const int MAX=5000000; vector prime; bool isprime[MAX]; void sieve(){ for(ll i=3; i0){ if(k%2==1){ ans=mulmod(ans, ap, m); } ap=mulmod(ap, ap, m); k/=2; } return ans; } random_device rnd; mt19937_64 mt(rnd()); bool is_prime(ll n){ for(int i=0; i<10; i++){ if(n%prime[i]==0) return false; } ll d=n-1; int k=0; while(d%2==0){ d/=2; k++; } uniform_int_distribution rndn(2, n-1); for(int i=0; i<20; i++){ ll a=rndn(mt); bool comp=1; ll ap=powmod(a, d, n); if(ap==1 || ap==n-1) continue; for(int r=1; r>n; ll a[9]; for(int i=0; i>a[i]; } ll ans=-1; while(1){ ll p10=1, p=0; for(int i=0; i=10) p10*=100; else p10*=10; } if(p