#ifndef INCLUDE_MODE
#define INCLUDE_MODE
// #define REACTIVE
// #define USE_GETLINE
/* #define SUBMIT_ONLY */
#define DEBUG_OUTPUT
// #define SAMPLE_CHECK dummy
#endif
#ifdef INCLUDE_MAIN
VO Solve()
{
CEXPR( int , p , 1009 );
using T = Mod
;
CIN( int , M , N );
CIN_A( int , 0 , M + 1 , K );
CIN_A( T , 0 , N + 1 , A );
auto PolynomialMultiplication = [&]( const vector& a , const vector& b ){
vector answer( N + 1 );
FOREQ( i , 0 , N ){
FOREQ( j , 0 , N - i ){
answer[i+j] += a[i] * b[j];
}
}
return answer;
};
auto PolynomialPower = [&]( const vector& a , int n ){
vector answer( N + 1 );
vector a_power = a;
answer[0] = 1;
while( n > 0 ){
( n & 1 ) == 1 ? answer = PolynomialMultiplication( answer , a_power ) : answer;
a_power = PolynomialMultiplication( a_power , a_power );
n >>= 1;
}
return answer;
};
vector p_power( M + 1 , N + 1 );
vector> A_power( M + 1 );
p_power[0] = 1;
int exponent = 0;
FOREQ( m , 0 , M ){
if( p_power[m] <= N ){
A_power[m] = PolynomialPower( A , K[m] );
if( m < M ){
p_power[m+1] = p_power[m] * p;
}
} else {
exponent += K[m];
}
}
vector answer( N + 1 , 0 );
answer[0] = 1;
FOREQ( m , 0 , M ){
if( N < p_power[m] ){
break;
}
vector nanswer( N + 1 );
FOREQ( i , 0 , N ){
int j_max = ( N - i ) / p_power[m];
FOREQ( j , 0 , j_max ){
nanswer[i+j*p_power[m]] += answer[i] * A_power[m][j];
}
}
answer = move( nanswer );
}
RETURN( answer *= Power( A[0] , exponent ) );
}
REPEAT_MAIN(1);
#else /* INCLUDE_MAIN */
#ifdef INCLUDE_SUB
/* COMPAREに使用。圧縮時は削除する。*/
MP Naive( ll N , ll M , ll K , const bool& debug_output = true )
{
MP answer{};
return answer;
}
/* COMPAREに使用。圧縮時は削除する。*/
MP Answer( ll N , ll M , ll K , const bool& debug_output = true )
{
MP answer{};
return answer;
}
/* 圧縮時は中身だけ削除する。*/
IN VO Experiment()
{
/* // 1変数 ../Contest/Template/Experiment/OneVariable.txt */
/* // 2変数 ../Contest/Template/Experiment/TwoVariable.txt */
/* // 3変数 ../Contest/Template/Experiment/ThreeVariable.txt */
}
/* 圧縮時は中身だけ削除する。*/
IN VO SmallTest()
{
/* // 数 ../Contest/Template/SmallTest/Number.txt */
/* // 配列 ../Contest/Template/SmallTest/Array.txt */
/* // 順列 ../Contest/Template/SmallTest/Permutation.txt */
/* // 文字列 ../Contest/Template/SmallTest/String.txt */
/* // グリッド ../Contest/Template/SmallTest/Grid.txt */
/* // グラフ ../Contest/Template/SmallTest/Graph.txt */
/* // 重み付きグラフ ../Contest/Template/SmallTest/WeightedGraph.txt */
/* // 区間クエリ ../Contest/Template/SmallTest/IntervalQuery.txt */
}
/* 圧縮時は中身だけ削除する。*/
IN VO RandomTest( const int& test_case_num )
{
/* // 数 ../Contest/Template/RandomTest/Number.txt */
/* // 配列 ../Contest/Template/RandomTest/Array.txt */
/* // 順列 ../Contest/Template/RandomTest/Permutation.txt */
/* // 文字列 ../Contest/Template/RandomTest/String.txt */
/* // グリッド ../Contest/Template/RandomTest/Grid.txt */
/* // グラフ ../Contest/Template/RandomTest/Graph.txt */
/* // 重み付きグラフ ../Contest/Template/RandomTest/WeightedGraph.txt */
/* // 区間クエリ ../Contest/Template/RandomTest/IntervalQuery.txt */
/* // 多種クエリ ../Contest/Template/RandomTest/MultiTypeQuery.txt */
REPEAT( test_case_num ){
}
}
#define INCLUDE_MAIN
#include __FILE__
#else /* INCLUDE_SUB */
#ifdef INCLUDE_LIBRARY
/* VVV 常設でないライブラリは以下に挿入する。*/
/* // Arithmetic ../Contest/Template/Library/Arithmetic.txt */
/* // BFS ../Contest/Template/Library/BFS.txt */
/* // BIT ../Contest/Template/Library/BIT.txt */
/* // CoordinateCompress ../Contest/Template/Library/CoordinateCompress.txt */
/* // DFS ../Contest/Template/Library/DFS.txt */
/* // DifferenceSequence ../Contest/Template/Library/DifferenceSequence.txt */
/* // Dijkstra ../Contest/Template/Library/Dijkstra.txt */
/* // Knapsack ../Contest/Template/Library/Knapsack.txt */
/* // Matrix ../Contest/Template/Library/Matrix.txt */
/* // Set ../Contest/Template/Library/Set.txt */
/* // Polynomial ../Contest/Template/Library/Polynomial.txt */
/* // SqrtDecomposition ../Contest/Template/Library/SqrtDecomposition.txt */
/* // UnionFind ../Contest/Template/Library/UnionFind.txt */
/*
- PrimeEnumeation: 素数列挙 (2KB)
Arithmetic/Prime/Enumeration/compress.txt
Arithmetic/Prime/Enumeration/Heap/compress.txt
- Counting: 素数列挙, 素数計数 (3KB)
Arithmetic/Prime/Enumeration/Counting/compress.txt
Arithmetic/Prime/Enumeration/Counting/Heap/compress.txt
- Factorisation: 素数列挙,最小素因子,素因数分解 (6KB)
Arithmetic/Prime/Factorisation/compress.txt
- Divisor: 素数列挙,最小素因子,素因数分解,約数計数,約数列挙 (7KB)
Arithmetic/Divisor/Enumeration/compress.txt
- EulerFunction: 素数列挙,最小素因子,素因数分解,オイラー関数 (6KB)
Arithmetic/Mod/Function/Euler/compress.txt
- MoeviusFunction: 素数列挙,最小素因子,素因数分解,メビウス関数 (6KB)
Arithmetic/Divisor/Moevius/compress.txt
- GCD: 最大公約数,最小公倍数 (1KB)
Arithmetic/Divisor/GCD/compress.txt
- Power: 羃乗 (1KB)
Arithmetic/Power/compress.txt
- GeometricProgressionSum: 冪乗,等比数列の和 (1KB)
Arithmetic/Power/GeometricProgressionSum/compress.txt
- DivisorSum: 冪乗,約数の冪乗和 (1KB)
Arithmetic/Divisor/Sum/compress.txt
- Sqrt: 平方根 (1KB)
Arithmetic/Sqrt/compress.txt
- DynamicMod: 動的mod (10KB)
Arithmetic/Mod/DynamicModulo/compress.txt
- ShifedMod: K未満は維持する動的mod (6KB)
Arithmetic/Mod/DynamicModulo/Shifted/compress.txt
*/
#ifdef DEBUG
#include "c:/Users/user/Documents/Programming/Mathematics/Arithmetic/Mod/DynamicModulo/Debug/a_Body.hpp"
#else
TE CE INT1 Residue(INT1 n,CO INT2& M)NE{RE MO(n < 0?((((++n)*= -1)%= M)*= -1)+= M - 1:n < M?n:n %= M);}
TE CL DynamicMods;TE CL COantsForDynamicMods{PU:COantsForDynamicMods()= delete;ST uint g_M;ST uint g_M_minus;ST int g_order;ST int g_order_minus_1;ST int g_order_minus_1_neg;ST bool g_M_is_prime;};
TE uint COantsForDynamicMods::g_M = 0;TE uint COantsForDynamicMods::g_M_minus = -1;TE int COantsForDynamicMods::g_order = 1;TE int COantsForDynamicMods::g_order_minus_1 = 0;TE int COantsForDynamicMods::g_order_minus_1_neg = 0;TE bool COantsForDynamicMods::g_M_is_prime = false;
#define DC_OF_CM_FOR_DYNAMIC_MOD(OPR)IN bool OP OPR(CO DynamicMods& n)CO NE
#define DC_OF_AR_FOR_DYNAMIC_MOD(OPR,EX)IN DynamicMods OP OPR(DynamicMods n)CO EX;
#define DF_OF_CM_FOR_DYNAMIC_MOD(OPR)TE IN bool DynamicMods::OP OPR(CO DynamicMods& n)CO NE{RE m_n OPR n.m_n;}
#define DF_OF_AR_FOR_DYNAMIC_MOD(OPR,EX,LEFT,OPR2)TE IN DynamicMods DynamicMods::OP OPR(DynamicMods n)CO EX{RE MO(LEFT OPR2 ## = *TH);}TE IN DynamicMods OP OPR(T n0,CO DynamicMods& n1)EX{RE MO(DynamicMods(MO(n0))OPR ## = n1);}
TE CL DynamicMods{PU:uint m_n;IN DynamicMods()NE;IN DynamicMods(CO DynamicMods& n)NE;IN DynamicMods(DynamicMods&& n)NE;TE IN DynamicMods(T n)NE;IN DynamicMods& OP=(DynamicMods n)NE;IN DynamicMods& OP+=(CO DynamicMods& n)NE;IN DynamicMods& OP-=(CO DynamicMods& n)NE;IN DynamicMods& OP*=(CO DynamicMods& n)NE;IN DynamicMods& OP/=(DynamicMods n);TE IN DynamicMods& OP<<=(INT n);TE IN DynamicMods& OP>>=(INT n);IN DynamicMods& OP++()NE;IN DynamicMods OP++(int)NE;IN DynamicMods& OP--()NE;IN DynamicMods OP--(int)NE;DC_OF_CM_FOR_DYNAMIC_MOD(==);DC_OF_CM_FOR_DYNAMIC_MOD(!=);DC_OF_CM_FOR_DYNAMIC_MOD(<);DC_OF_CM_FOR_DYNAMIC_MOD(<=);DC_OF_CM_FOR_DYNAMIC_MOD(>);DC_OF_CM_FOR_DYNAMIC_MOD(>=);DC_OF_AR_FOR_DYNAMIC_MOD(+,NE);DC_OF_AR_FOR_DYNAMIC_MOD(-,NE);DC_OF_AR_FOR_DYNAMIC_MOD(*,NE);DC_OF_AR_FOR_DYNAMIC_MOD(/,);TE IN DynamicMods OP^(INT EX)CO;TE IN DynamicMods OP<<(INT n)CO;TE IN DynamicMods OP>>(INT n)CO;IN DynamicMods OP-()CO NE;IN DynamicMods& SignInvert()NE;IN DynamicMods& Invert();TE IN DynamicMods& PW(INT EX);IN VO swap(DynamicMods& n)NE;IN CRUI RP()CO NE;ST IN DynamicMods DeRP(uint n)NE;ST IN CO DynamicMods& Inverse(CRUI n);ST IN CO DynamicMods& Factorial(CRUI n);ST IN CO DynamicMods& FactorialInverse(CRUI n);ST IN DynamicMods Combination(CRUI n,CRUI i);ST IN CO DynamicMods& zero()NE;ST IN CO DynamicMods& one()NE;ST IN CRUI GetModulo()NE;ST IN VO SetModulo(CRUI M,CRI order_minus_1 = -1)NE;TE IN DynamicMods& PositivePW(INT EX)NE;TE IN DynamicMods& NonNegativePW(INT EX)NE;US COants = COantsForDynamicMods;};
US DynamicMod = DynamicMods<0>;
TE IN DynamicMods::DynamicMods()NE:m_n(){}TE IN DynamicMods::DynamicMods(CO DynamicMods& n)NE:m_n(n.m_n){}TE IN DynamicMods::DynamicMods(DynamicMods&& n)NE:m_n(MO(n.m_n)){}TE TE IN DynamicMods::DynamicMods(T n)NE:m_n(Residue(uint(MO(n)),COants::g_M)){ST_AS(is_COructible_v >);}TE IN DynamicMods& DynamicMods::OP=(DynamicMods n)NE{m_n = MO(n.m_n);RE *TH;}TE IN DynamicMods& DynamicMods::OP+=(CO DynamicMods& n)NE{(m_n += n.m_n)< COants::g_M?m_n:m_n -= COants::g_M;RE *TH;}TE IN DynamicMods& DynamicMods::OP-=(CO DynamicMods& n)NE{m_n < n.m_n?(m_n += COants::g_M)-= n.m_n:m_n -= n.m_n;RE *TH;}TE IN DynamicMods& DynamicMods::OP*=(CO DynamicMods& n)NE{m_n = Residue(MO(ull(m_n)* n.m_n),COants::g_M);RE *TH;}TE IN DynamicMods& DynamicMods::OP/=(DynamicMods n){RE OP*=(n.Invert());}TE TE IN DynamicMods& DynamicMods::OP<<=(INT n){AS(n >= 0);RE *TH *= DynamicMods(2).NonNegativePW(MO(n));}TE TE IN DynamicMods& DynamicMods::OP>>=(INT n){AS(n >= 0);WH(n-- > 0){((m_n & 1)== 0?m_n:m_n += COants::g_M)>>= 1;}RE *TH;}TE IN DynamicMods& DynamicMods::OP++()NE{m_n < COants::g_M_minus?++m_n:m_n = 0;RE *TH;}TE IN DynamicMods DynamicMods::OP++(int)NE{DynamicMods n{*TH};OP++();RE n;}TE IN DynamicMods& DynamicMods::OP--()NE{m_n == 0?m_n = COants::g_M_minus:--m_n;RE *TH;}TE IN DynamicMods DynamicMods::OP--(int)NE{DynamicMods n{*TH};OP--();RE n;}DF_OF_CM_FOR_DYNAMIC_MOD(==);DF_OF_CM_FOR_DYNAMIC_MOD(!=);DF_OF_CM_FOR_DYNAMIC_MOD(>);DF_OF_CM_FOR_DYNAMIC_MOD(>=);DF_OF_CM_FOR_DYNAMIC_MOD(<);DF_OF_CM_FOR_DYNAMIC_MOD(<=);DF_OF_AR_FOR_DYNAMIC_MOD(+,NE,n,+);DF_OF_AR_FOR_DYNAMIC_MOD(-,NE,n.SignInvert(),+);DF_OF_AR_FOR_DYNAMIC_MOD(*,NE,n,*);DF_OF_AR_FOR_DYNAMIC_MOD(/,,n.Invert(),*);TE TE IN DynamicMods DynamicMods::OP^(INT EX)CO{RE MO(DynamicMods(*TH).PW(MO(EX)));}TE TE IN DynamicMods DynamicMods::OP<<(INT n)CO{RE MO(DynamicMods(*TH)<<= MO(n));}TE TE IN DynamicMods DynamicMods::OP>>(INT n)CO{RE MO(DynamicMods(*TH)>>= MO(n));}TE IN DynamicMods DynamicMods::OP-()CO NE{RE MO(DynamicMods(*TH).SignInvert());}TE IN DynamicMods& DynamicMods::SignInvert()NE{m_n > 0?m_n = COants::g_M - m_n:m_n;RE *TH;}TE IN DynamicMods& DynamicMods::Invert(){RE m_n <(COants::g_M_is_prime?1e6:3e4)?*TH = Inverse(m_n):NonNegativePW(COants::g_order_minus_1);}TE TE IN DynamicMods& DynamicMods::PositivePW(INT EX)NE{DynamicMods PW{*TH};EX--;WH(EX != 0){(EX & 1)== 1?*TH *= PW:*TH;EX >>= 1;PW *= PW;}RE *TH;}TE TE IN DynamicMods& DynamicMods::NonNegativePW(INT EX)NE{RE EX == 0?(m_n = 1,*TH):PositivePW(MO(EX));}TE TE IN DynamicMods& DynamicMods::PW(INT EX){bool neg = EX < 0;RE neg?PositivePW(ll(MO(EX %= COants::g_order))* COants::g_order_minus_1_neg % COants::g_order):NonNegativePW(MO(EX));}TE IN VO DynamicMods::swap(DynamicMods& n)NE{std::swap(m_n,n.m_n);}TE IN CO DynamicMods& DynamicMods::Inverse(CRUI n){ST VE> memory ={zero(),one()};ST uint LE_curr = 2;AS(COants::g_M == 1||(0 < n && n < COants::g_M));WH(LE_curr <= n){memory.push_back(COants::g_M_is_prime?DeRP(COants::g_M - memory[COants::g_M % LE_curr].m_n * ull(COants::g_M / LE_curr)% COants::g_M):DeRP(n).NonNegativePW(COants::g_order_minus_1));LE_curr++;}RE memory[n];}TE IN CO DynamicMods& DynamicMods::Factorial(CRUI n){ST VE> memory ={one(),one()};ST uint LE_curr = 2;if(COants::g_M <= n){RE zero();}WH(LE_curr <= n && memory.back().m_n != 0){memory.push_back(memory.back()* DeRP(LE_curr));LE_curr++;}RE LE_curr <= n?memory.back():memory[n];}TE IN CO DynamicMods& DynamicMods::FactorialInverse(CRUI n){ST VE> memory ={one(),one()};ST uint LE_curr = 2;WH(LE_curr <= n){memory.push_back(memory[LE_curr - 1]* Inverse(LE_curr));LE_curr++;}RE memory[n];}TE IN DynamicMods DynamicMods::Combination(CRUI n,CRUI i){RE i <= n?Factorial(n)* FactorialInverse(i)* FactorialInverse(n - i):zero();}TE IN CRUI DynamicMods::RP()CO NE{RE m_n;}TE IN DynamicMods DynamicMods::DeRP(uint n)NE{DynamicMods n_copy{};n_copy.m_n = MO(n);RE n_copy;}TE IN CO DynamicMods& DynamicMods::zero()NE{ST CO DynamicMods z{};RE z;}TE IN CO DynamicMods& DynamicMods::one()NE{ST CO DynamicMods o{1};RE o;}TE IN CRUI DynamicMods::GetModulo()NE{RE COants::g_M;}TE IN VO DynamicMods::SetModulo(CRUI M,CRI order_minus_1)NE{COants::g_M = M;COants::g_M_minus = M - 1;COants::g_order = order_minus_1 == -1?M - 1:order_minus_1+1;COants::g_order_minus_1 = COants::g_order-1;COants::g_order_minus_1_neg = -COants::g_order_minus_1;COants::g_M_is_prime = order_minus_1 == -1;}TE IN DynamicMods Inverse(CO DynamicMods& n){RE MO(DynamicMods(n).Invert());}TE IN DynamicMods PW(DynamicMods n,INT EX){RE MO(n.PW(MO(EX)));}TE IN VO swap(DynamicMods& n0,DynamicMods& n1)NE{n0.swap(n1);}TE IN string to_string(CO DynamicMods& n)NE{RE to_string(n.RP())+ " + " + to_string(DynamicMods::GetModulo())+ "Z";}TE IN IS& OP>>(IS& is,DynamicMods& n){ll m;is >> m;n = m;RE is;}TE IN OS& OP<<(OS& os,CO DynamicMods& n){RE os << n.RP();}
TE DC_OF_HASH( DynamicMods );TE DF_OF_HASH_FOR_MOD( DynamicMods );
TE INT1 GCD(CO INT1& b_0,CO INT2& b_1){INT1 a_0 = b_0 < 0?-b_0:b_0;INT1 a_1 = b_1 < 0?-b_1:b_1;WH(a_1 != 0){swap(a_0 %= a_1,a_1);}RE a_0;}TE IN INT1 LCM(CO INT1& b_0,CO INT2& b_1){RE(b_0 == 0 && b_1 == 0)?0:(b_0 / GCD(b_0,b_1))* b_1;}
#endif
/* AAA 常設でないライブラリは以上に挿入する。*/
#define INCLUDE_SUB
#include __FILE__
#else /* INCLUDE_LIBRARY */
#ifdef DEBUG
#define _GLIBCXX_DEBUG
#else
#pragma GCC optimize ( "O3" )
#pragma GCC optimize ( "unroll-loops" )
#pragma GCC target ( "sse4.2,fma,avx2,popcnt,lzcnt,bmi2" )
#define REPEAT_MAIN( BOUND ) START_MAIN; CEXPR( int , bound_test_case_num , BOUND ); int test_case_num = 1; if CE( bound_test_case_num > 1 ){ SET_ASSERT( test_case_num , 1 , bound_test_case_num ); } FINISH_MAIN
#define FINISH_MAIN REPEAT( test_case_num ){ if CE( bound_test_case_num > 1 ){ CERR( "testcase " , VARIABLE_FOR_REPEAT_test_case_num , ":" ); } Solve(); CERR( "" ); } }
#define DEXPR( LL , BOUND , VALUE1 , VALUE2 ) CEXPR( LL , BOUND , VALUE1 )
#define ASSERT( A , MIN , MAX ) AS( ( MIN ) <= A && A <= ( MAX ) )
#ifdef USE_GETLINE
#define SET_SEPARATE( SEPARATOR , ... ) VariadicGetline( cin , SEPARATOR , __VA_ARGS__ )
#define SET( ... ) SET_SEPARATE( '\n' , __VA_ARGS__ )
#define GETLINE_SEPARATE( SEPARATOR , ... ) string __VA_ARGS__; SET_SEPARATE( SEPARATOR , __VA_ARGS__ )
#define GETLINE( ... ) GETLINE_SEPARATE( '\n' , __VA_ARGS__ )
#else
#define SET( ... ) VariadicCin( cin , __VA_ARGS__ )
#define CIN( LL , ... ) LL __VA_ARGS__; SET( __VA_ARGS__ )
#define SET_A( I , N , ... ) VariadicResize( N + I , __VA_ARGS__ ); FOR( VARIABLE_FOR_SET_A , 0 , N ){ VariadicSet( cin , VARIABLE_FOR_SET_A + I , __VA_ARGS__ ); }
#define CIN_A( LL , I , N , ... ) VE __VA_ARGS__; SET_A( I , N , __VA_ARGS__ )
#define CIN_AA( LL , I0 , N0 , I1 , N1 , VAR ) VE> VAR( N0 + I0 ); FOR( VARIABLE_FOR_CIN_AA , 0 , N0 ){ SET_A( I1 , N1 , VAR[VARIABLE_FOR_CIN_AA + I0] ); }
#endif
#define SET_ASSERT( A , MIN , MAX ) SET( A ); ASSERT( A , MIN , MAX )
#define SOLVE_ONLY
#define COUT( ... ) VariadicCout( cout , __VA_ARGS__ ) << ENDL
#define COUTNS( ... ) VariadicCoutNonSep( cout , __VA_ARGS__ )
#define CERR( ... )
#define CERRNS( ... )
#define COUT_A( I , N , A ) CoutArray( cout , I , N , A ) << ENDL
#define CERR_A( I , N , A )
#endif
#ifdef REACTIVE
#ifdef DEBUG
#define RSET( A , ... ) A = __VA_ARGS__
#else
#define RSET( A , ... ) SET( A )
#endif
#define RCIN( LL , A , ... ) LL A; RSET( A , __VA_ARGS__ )
#define ENDL endl
#else
#define ENDL "\n"
#endif
#include
using namespace std;
#define ATT __attribute__( ( target( "sse4.2,fma,avx2,popcnt,lzcnt,bmi2" ) ) )
#define START_MAIN int main(){ ios_base::sync_with_stdio( false ); cin.tie( nullptr )
#define START_WATCH chrono::system_clock::time_point watch = chrono::system_clock::now(); double loop_average_time = 0.0 , loop_start_time = 0.0 , current_time = 0.0; int loop_count = 0
#define CURRENT_TIME ( current_time = static_cast( chrono::duration_cast( chrono::system_clock::now() - watch ).count() / 1000.0 ) )
#define CHECK_WATCH( TL_MS ) ( CURRENT_TIME , loop_count == 0 ? loop_start_time = current_time : loop_average_time = ( current_time - loop_start_time ) / loop_count , ++loop_count , current_time < TL_MS - loop_average_time * 2 - 100.0 )
#define CEXPR( LL , BOUND , VALUE ) CE LL BOUND = VALUE
#define SET_A_ASSERT( I , N , A , MIN , MAX ) FOR( VARIABLE_FOR_SET_A , 0 , N ){ SET_ASSERT( A[VARIABLE_FOR_SET_A + I] , MIN , MAX ); }
#define SET_AA_ASSERT( I0 , N0 , I1 , N1 , A , MIN , MAX ) FOR( VARIABLE_FOR_SET_AA0 , 0 , N0 ){ FOR( VARIABLE_FOR_SET_AA1 , 0 , N1 ){ SET_ASSERT( A[VARIABLE_FOR_SET_AA0 + I0][VARIABLE_FOR_SET_AA1 + I1] , MIN , MAX ); } }
#define CIN_ASSERT( A , MIN , MAX ) decldecay_t( MAX ) A; SET_ASSERT( A , MIN , MAX )
#define CIN_A_ASSERT( I , N , A , MIN , MAX ) vector A( N + I ); SET_A_ASSERT( I , N , A , MIN , MAX )
#define CIN_AA_ASSERT( I0 , N0 , I1 , N1 , A , MIN , MAX ) vector A( N0 + I0 , vector( N1 + I1 ) ); SET_AA_ASSERT( I0 , N0 , I1 , N1 , A , MIN , MAX )
#define FOR( VAR , INITIAL , FINAL_PLUS_ONE ) for( decldecay_t( FINAL_PLUS_ONE ) VAR = INITIAL ; VAR < FINAL_PLUS_ONE ; VAR ++ )
#define FOREQ( VAR , INITIAL , FINAL ) for( decldecay_t( FINAL ) VAR = INITIAL ; VAR <= FINAL ; VAR ++ )
#define FOREQINV( VAR , INITIAL , FINAL ) for( decldecay_t( INITIAL ) VAR = INITIAL ; VAR + 1 > FINAL ; VAR -- )
#define ITR( ARRAY ) auto begin_ ## ARRAY = ARRAY .BE() , itr_ ## ARRAY = begin_ ## ARRAY , end_ ## ARRAY = ARRAY .EN()
#define FOR_ITR( ARRAY ) for( ITR( ARRAY ) , itr = itr_ ## ARRAY ; itr_ ## ARRAY != end_ ## ARRAY ; itr_ ## ARRAY ++ , itr++ )
#define RUN( ARRAY , ... ) for( auto&& __VA_ARGS__ : ARRAY )
#define REPEAT( HOW_MANY_TIMES ) FOR( VARIABLE_FOR_REPEAT , 0 , HOW_MANY_TIMES )
#define SET_PRECISION( DECIMAL_DIGITS ) cout << fixed << setprecision( DECIMAL_DIGITS ); cerr << fixed << setprecision( DECIMAL_DIGITS )
#define RETURN( ... ) SOLVE_ONLY; COUT( __VA_ARGS__ ); RE
#define COMPARE( ... ) auto naive = Naive( __VA_ARGS__ , false ); auto answer = Answer( __VA_ARGS__ , false ); bool match = naive == answer; CERR( "(" , #__VA_ARGS__ , ") == (" , __VA_ARGS__ , ") : Naive == " , naive , match ? "==" : "!=" , answer , "== Answer" ); if( !match ){ RE; }
/* 圧縮用 */
#define TE template
#define TY typename
#define US using
#define ST static
#define AS assert
#define IN inline
#define CL class
#define PU public
#define OP operator
#define CE constexpr
#define CO const
#define NE noexcept
#define RE return
#define WH while
#define VO void
#define VE vector
#define LI list
#define BE begin
#define EN end
#define SZ size
#define LE length
#define PW Power
#define MO move
#define TH this
#define CRI CO int&
#define CRUI CO uint&
#define CRL CO ll&
#define VI virtual
#define IS basic_istream
#define OS basic_ostream
#define ST_AS static_assert
#define reMO_CO remove_const
#define is_COructible_v is_constructible_v
#define rBE rbegin
/* 型のエイリアス */
#define decldecay_t(VAR)decay_t
TE US ret_t = decltype(declval()(declval()...));
TE US inner_t = TY T::type;
US uint = unsigned int;
US ll = long long;
US ull = unsigned long long;
US ld = long double;
US lld = __float128;
TE US T2 = pair