#pragma once
// This file is a fork of AtCoder Library.#define E6NLAQ_INTERNAL_MATH_HPP
#include<utility>#ifdef _MSC_VER
#include<intrin.h>
#endif
namespacee6nlaq{namespaceinternal{// @param m `1 <= m`// @return x mod mconstexprlonglongsafe_mod(longlongx,longlongm){x%=m;if(x<0)x+=m;returnx;}// Fast modular multiplication by barrett reduction// Reference: https://en.wikipedia.org/wiki/Barrett_reduction// NOTE: reconsider after Ice Lakestructbarrett{unsignedint_m;unsignedlonglongim;// @param m `1 <= m`explicitbarrett(unsignedintm):_m(m),im((unsignedlonglong)(-1)/m+1){}// @return munsignedintumod()const{return_m;}// @param a `0 <= a < m`// @param b `0 <= b < m`// @return `a * b % m`unsignedintmul(unsignedinta,unsignedintb)const{// [1] m = 1// a = b = im = 0, so okay// [2] m >= 2// im = ceil(2^64 / m)// -> im * m = 2^64 + r (0 <= r < m)// let z = a*b = c*m + d (0 <= c, d < m)// a*b * im = (c*m + d) * im = c*(im*m) + d*im = c*2^64 + c*r + d*im// c*r + d*im < m * m + m * im < m * m + 2^64 + m <= 2^64 + m * (m + 1) < 2^64 * 2// ((ab * im) >> 64) == c or c + 1unsignedlonglongz=a;z*=b;#ifdef _MSC_VER
unsignedlonglongx;_umul128(z,im,&x);#else
unsignedlonglongx=(unsignedlonglong)(((unsigned__int128)(z)*im)>>64);#endif
unsignedlonglongy=x*_m;return(unsignedint)(z-y+(z<y?_m:0));}};// @param n `0 <= n`// @param m `1 <= m`// @return `(x ** n) % m`constexprlonglongpow_mod_constexpr(longlongx,longlongn,intm){if(m==1)return0;unsignedint_m=(unsignedint)(m);unsignedlonglongr=1;unsignedlonglongy=safe_mod(x,m);while(n){if(n&1)r=(r*y)%_m;y=(y*y)%_m;n>>=1;}returnr;}// Reference:// M. Forisek and J. Jancina,// Fast Primality Testing for Integers That Fit into a Machine Word// @param n `0 <= n`constexprboolis_prime_constexpr(intn){if(n<=1)returnfalse;if(n==2||n==7||n==61)returntrue;if(n%2==0)returnfalse;longlongd=n-1;while(d%2==0)d/=2;constexprlonglongbases[3]={2,7,61};for(longlonga:bases){longlongt=d;longlongy=pow_mod_constexpr(a,t,n);while(t!=n-1&&y!=1&&y!=n-1){y=y*y%n;t<<=1;}if(y!=n-1&&t%2==0){returnfalse;}}returntrue;}template<intn>constexprboolis_prime=is_prime_constexpr(n);// @param b `1 <= b`// @return pair(g, x) s.t. g = gcd(a, b), xa = g (mod b), 0 <= x < b/gconstexprstd::pair<longlong,longlong>inv_gcd(longlonga,longlongb){a=safe_mod(a,b);if(a==0)return{b,0};// Contracts:// [1] s - m0 * a = 0 (mod b)// [2] t - m1 * a = 0 (mod b)// [3] s * |m1| + t * |m0| <= blonglongs=b,t=a;longlongm0=0,m1=1;while(t){longlongu=s/t;s-=t*u;m0-=m1*u;// |m1 * u| <= |m1| * s <= b// [3]:// (s - t * u) * |m1| + t * |m0 - m1 * u|// <= s * |m1| - t * u * |m1| + t * (|m0| + |m1| * u)// = s * |m1| + t * |m0| <= bautotmp=s;s=t;t=tmp;tmp=m0;m0=m1;m1=tmp;}// by [3]: |m0| <= b/g// by g != b: |m0| < b/gif(m0<0)m0+=b/s;return{s,m0};}// Compile time primitive root// @param m must be prime// @return primitive root (and minimum in now)constexprintprimitive_root_constexpr(intm){if(m==2)return1;if(m==167772161)return3;if(m==469762049)return3;if(m==754974721)return11;if(m==998244353)return3;intdivs[20]={};divs[0]=2;intcnt=1;intx=(m-1)/2;while(x%2==0)x/=2;for(inti=3;(longlong)(i)*i<=x;i+=2){if(x%i==0){divs[cnt++]=i;while(x%i==0){x/=i;}}}if(x>1){divs[cnt++]=x;}for(intg=2;;g++){boolok=true;for(inti=0;i<cnt;i++){if(pow_mod_constexpr(g,(m-1)/divs[i],m)==1){ok=false;break;}}if(ok)returng;}}template<intm>constexprintprimitive_root=primitive_root_constexpr(m);// @param n `n < 2^32`// @param m `1 <= m < 2^32`// @return sum_{i=0}^{n-1} floor((ai + b) / m) (mod 2^64)unsignedlonglongfloor_sum_unsigned(unsignedlonglongn,unsignedlonglongm,unsignedlonglonga,unsignedlonglongb){unsignedlonglongans=0;while(true){if(a>=m){ans+=n*(n-1)/2*(a/m);a%=m;}if(b>=m){ans+=n*(b/m);b%=m;}unsignedlonglongy_max=a*n+b;if(y_max<m)break;// y_max < m * (n + 1)// floor(y_max / m) <= nn=(unsignedlonglong)(y_max/m);b=(unsignedlonglong)(y_max%m);std::swap(m,a);}returnans;}}// namespace internal}// namespace e6nlaq
#line 2 "include/e6nlaq/internal/math.hpp"
// This file is a fork of AtCoder Library.#define E6NLAQ_INTERNAL_MATH_HPP
#include<utility>#ifdef _MSC_VER
#include<intrin.h>
#endif
namespacee6nlaq{namespaceinternal{// @param m `1 <= m`// @return x mod mconstexprlonglongsafe_mod(longlongx,longlongm){x%=m;if(x<0)x+=m;returnx;}// Fast modular multiplication by barrett reduction// Reference: https://en.wikipedia.org/wiki/Barrett_reduction// NOTE: reconsider after Ice Lakestructbarrett{unsignedint_m;unsignedlonglongim;// @param m `1 <= m`explicitbarrett(unsignedintm):_m(m),im((unsignedlonglong)(-1)/m+1){}// @return munsignedintumod()const{return_m;}// @param a `0 <= a < m`// @param b `0 <= b < m`// @return `a * b % m`unsignedintmul(unsignedinta,unsignedintb)const{// [1] m = 1// a = b = im = 0, so okay// [2] m >= 2// im = ceil(2^64 / m)// -> im * m = 2^64 + r (0 <= r < m)// let z = a*b = c*m + d (0 <= c, d < m)// a*b * im = (c*m + d) * im = c*(im*m) + d*im = c*2^64 + c*r + d*im// c*r + d*im < m * m + m * im < m * m + 2^64 + m <= 2^64 + m * (m + 1) < 2^64 * 2// ((ab * im) >> 64) == c or c + 1unsignedlonglongz=a;z*=b;#ifdef _MSC_VER
unsignedlonglongx;_umul128(z,im,&x);#else
unsignedlonglongx=(unsignedlonglong)(((unsigned__int128)(z)*im)>>64);#endif
unsignedlonglongy=x*_m;return(unsignedint)(z-y+(z<y?_m:0));}};// @param n `0 <= n`// @param m `1 <= m`// @return `(x ** n) % m`constexprlonglongpow_mod_constexpr(longlongx,longlongn,intm){if(m==1)return0;unsignedint_m=(unsignedint)(m);unsignedlonglongr=1;unsignedlonglongy=safe_mod(x,m);while(n){if(n&1)r=(r*y)%_m;y=(y*y)%_m;n>>=1;}returnr;}// Reference:// M. Forisek and J. Jancina,// Fast Primality Testing for Integers That Fit into a Machine Word// @param n `0 <= n`constexprboolis_prime_constexpr(intn){if(n<=1)returnfalse;if(n==2||n==7||n==61)returntrue;if(n%2==0)returnfalse;longlongd=n-1;while(d%2==0)d/=2;constexprlonglongbases[3]={2,7,61};for(longlonga:bases){longlongt=d;longlongy=pow_mod_constexpr(a,t,n);while(t!=n-1&&y!=1&&y!=n-1){y=y*y%n;t<<=1;}if(y!=n-1&&t%2==0){returnfalse;}}returntrue;}template<intn>constexprboolis_prime=is_prime_constexpr(n);// @param b `1 <= b`// @return pair(g, x) s.t. g = gcd(a, b), xa = g (mod b), 0 <= x < b/gconstexprstd::pair<longlong,longlong>inv_gcd(longlonga,longlongb){a=safe_mod(a,b);if(a==0)return{b,0};// Contracts:// [1] s - m0 * a = 0 (mod b)// [2] t - m1 * a = 0 (mod b)// [3] s * |m1| + t * |m0| <= blonglongs=b,t=a;longlongm0=0,m1=1;while(t){longlongu=s/t;s-=t*u;m0-=m1*u;// |m1 * u| <= |m1| * s <= b// [3]:// (s - t * u) * |m1| + t * |m0 - m1 * u|// <= s * |m1| - t * u * |m1| + t * (|m0| + |m1| * u)// = s * |m1| + t * |m0| <= bautotmp=s;s=t;t=tmp;tmp=m0;m0=m1;m1=tmp;}// by [3]: |m0| <= b/g// by g != b: |m0| < b/gif(m0<0)m0+=b/s;return{s,m0};}// Compile time primitive root// @param m must be prime// @return primitive root (and minimum in now)constexprintprimitive_root_constexpr(intm){if(m==2)return1;if(m==167772161)return3;if(m==469762049)return3;if(m==754974721)return11;if(m==998244353)return3;intdivs[20]={};divs[0]=2;intcnt=1;intx=(m-1)/2;while(x%2==0)x/=2;for(inti=3;(longlong)(i)*i<=x;i+=2){if(x%i==0){divs[cnt++]=i;while(x%i==0){x/=i;}}}if(x>1){divs[cnt++]=x;}for(intg=2;;g++){boolok=true;for(inti=0;i<cnt;i++){if(pow_mod_constexpr(g,(m-1)/divs[i],m)==1){ok=false;break;}}if(ok)returng;}}template<intm>constexprintprimitive_root=primitive_root_constexpr(m);// @param n `n < 2^32`// @param m `1 <= m < 2^32`// @return sum_{i=0}^{n-1} floor((ai + b) / m) (mod 2^64)unsignedlonglongfloor_sum_unsigned(unsignedlonglongn,unsignedlonglongm,unsignedlonglonga,unsignedlonglongb){unsignedlonglongans=0;while(true){if(a>=m){ans+=n*(n-1)/2*(a/m);a%=m;}if(b>=m){ans+=n*(b/m);b%=m;}unsignedlonglongy_max=a*n+b;if(y_max<m)break;// y_max < m * (n + 1)// floor(y_max / m) <= nn=(unsignedlonglong)(y_max/m);b=(unsignedlonglong)(y_max%m);std::swap(m,a);}returnans;}}// namespace internal}// namespace e6nlaq