#define PROBLEM "https://judge.yosupo.jp/problem/convolution_mod_1000000007"
//#include"../../template/template.hpp"//usingnamespaceNyaan;#include"../../modint/montgomery-modint.hpp"
#include"../../ntt/schoenhage-strassen-radix2.hpp"usingmint=LazyMontgomeryModInt<1000000007>;usingvm=V<mint>;Schoenhage_Strassen_radix2<mint>ss;/*
#include "misc/timer.hpp"
void calc() {
int N = TEN(5) * 5;
vm a(N), b(N);
int e = 1;
each(x, a) x = e, ++e;
each(x, b) x = e, ++e;
Timer timer;
auto c = ss.multiply(a, b);
cerr << c.first.size() << " " << timer.elapsed() << endl;
}
void test() {
for (int n = 1, m = 1; n < 100; n += 2, m += 2) {
vm a(n), b(m);
int e = 1;
each(x, a) x = e, e += 1;
// each(x, b) x = e, e += 1;
b = a;
auto [c, d] = ss.multiply(a, b);
mint inv = mint(1 << d).inverse();
each(x, c) x *= inv;
vm C(n + m - 1);
rep(i, n) rep(j, m) C[i + j] += a[i] * b[j];
assert(C == c);
}
}
*/voidNyaan::solve(){// test();// calc();ini(N,M);vma(N),b(M);in(a,b);auto[c,d]=ss.multiply(a,b);mintinv=mint(1<<d).inverse();each(x,c)x*=inv;out(c);}
#line 1 "verify/verify-yosupo-ntt/yosupo-convolution-schoenhage-radix2.test.cpp"
#define PROBLEM "https://judge.yosupo.jp/problem/convolution_mod_1000000007"
//#line 2 "template/template.hpp"
usingnamespacestd;// intrinstic#include<immintrin.h>#include<algorithm>
#include<array>
#include<bitset>
#include<cassert>
#include<cctype>
#include<cfenv>
#include<cfloat>
#include<chrono>
#include<cinttypes>
#include<climits>
#include<cmath>
#include<complex>
#include<cstdarg>
#include<cstddef>
#include<cstdint>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<deque>
#include<fstream>
#include<functional>
#include<initializer_list>
#include<iomanip>
#include<ios>
#include<iostream>
#include<istream>
#include<iterator>
#include<limits>
#include<list>
#include<map>
#include<memory>
#include<new>
#include<numeric>
#include<ostream>
#include<queue>
#include<random>
#include<set>
#include<sstream>
#include<stack>
#include<streambuf>
#include<string>
#include<tuple>
#include<type_traits>
#include<typeinfo>
#include<unordered_map>
#include<unordered_set>
#include<utility>
#include<vector>// utility#line 1 "template/util.hpp"
namespaceNyaan{usingll=longlong;usingi64=longlong;usingu64=unsignedlonglong;usingi128=__int128_t;usingu128=__uint128_t;template<typenameT>usingV=vector<T>;template<typenameT>usingVV=vector<vector<T>>;usingvi=vector<int>;usingvl=vector<longlong>;usingvd=V<double>;usingvs=V<string>;usingvvi=vector<vector<int>>;usingvvl=vector<vector<longlong>>;template<typenameT>usingminpq=priority_queue<T,vector<T>,greater<T>>;template<typenameT,typenameU>structP:pair<T,U>{template<typename...Args>P(Args...args):pair<T,U>(args...){}usingpair<T,U>::first;usingpair<T,U>::second;P&operator+=(constP&r){first+=r.first;second+=r.second;return*this;}P&operator-=(constP&r){first-=r.first;second-=r.second;return*this;}P&operator*=(constP&r){first*=r.first;second*=r.second;return*this;}template<typenameS>P&operator*=(constS&r){first*=r,second*=r;return*this;}Poperator+(constP&r)const{returnP(*this)+=r;}Poperator-(constP&r)const{returnP(*this)-=r;}Poperator*(constP&r)const{returnP(*this)*=r;}template<typenameS>Poperator*(constS&r)const{returnP(*this)*=r;}Poperator-()const{returnP{-first,-second};}};usingpl=P<ll,ll>;usingpi=P<int,int>;usingvp=V<pl>;constexprintinf=1001001001;constexprlonglonginfLL=4004004004004004004LL;template<typenameT>intsz(constT&t){returnt.size();}template<typenameT,typenameU>inlineboolamin(T&x,Uy){return(y<x)?(x=y,true):false;}template<typenameT,typenameU>inlineboolamax(T&x,Uy){return(x<y)?(x=y,true):false;}template<typenameT>inlineTMax(constvector<T>&v){return*max_element(begin(v),end(v));}template<typenameT>inlineTMin(constvector<T>&v){return*min_element(begin(v),end(v));}template<typenameT>inlinelonglongSum(constvector<T>&v){returnaccumulate(begin(v),end(v),0LL);}template<typenameT>intlb(constvector<T>&v,constT&a){returnlower_bound(begin(v),end(v),a)-begin(v);}template<typenameT>intub(constvector<T>&v,constT&a){returnupper_bound(begin(v),end(v),a)-begin(v);}constexprlonglongTEN(intn){longlongret=1,x=10;for(;n;x*=x,n>>=1)ret*=(n&1?x:1);returnret;}template<typenameT,typenameU>pair<T,U>mkp(constT&t,constU&u){returnmake_pair(t,u);}template<typenameT>vector<T>mkrui(constvector<T>&v,boolrev=false){vector<T>ret(v.size()+1);if(rev){for(inti=int(v.size())-1;i>=0;i--)ret[i]=v[i]+ret[i+1];}else{for(inti=0;i<int(v.size());i++)ret[i+1]=ret[i]+v[i];}returnret;};template<typenameT>vector<T>mkuni(constvector<T>&v){vector<T>ret(v);sort(ret.begin(),ret.end());ret.erase(unique(ret.begin(),ret.end()),ret.end());returnret;}template<typenameF>vector<int>mkord(intN,Ff){vector<int>ord(N);iota(begin(ord),end(ord),0);sort(begin(ord),end(ord),f);returnord;}template<typenameT>vector<int>mkinv(vector<T>&v){intmax_val=*max_element(begin(v),end(v));vector<int>inv(max_val+1,-1);for(inti=0;i<(int)v.size();i++)inv[v[i]]=i;returninv;}vector<int>mkiota(intn){vector<int>ret(n);iota(begin(ret),end(ret),0);returnret;}template<typenameT>Tmkrev(constT&v){Tw{v};reverse(begin(w),end(w));returnw;}template<typenameT>boolnxp(T&v){returnnext_permutation(begin(v),end(v));}// 返り値の型は入力の T に依存// i 要素目 : [0, a[i])template<typenameT>vector<vector<T>>product(constvector<T>&a){vector<vector<T>>ret;vector<T>v;autodfs=[&](autorc,inti)->void{if(i==(int)a.size()){ret.push_back(v);return;}for(intj=0;j<a[i];j++)v.push_back(j),rc(rc,i+1),v.pop_back();};dfs(dfs,0);returnret;}// F : function(void(T&)), mod を取る操作// T : 整数型のときはオーバーフローに注意するtemplate<typenameT>TPower(Ta,longlongn,constT&I,constfunction<void(T&)>&f){Tres=I;for(;n;f(a=a*a),n>>=1){if(n&1)f(res=res*a);}returnres;}// T : 整数型のときはオーバーフローに注意するtemplate<typenameT>TPower(Ta,longlongn,constT&I=T{1}){returnPower(a,n,I,function<void(T&)>{[](T&)->void{}});}template<typenameT>TRev(constT&v){Tres=v;reverse(begin(res),end(res));returnres;}template<typenameT>vector<T>Transpose(constvector<T>&v){usingU=typenameT::value_type;if(v.empty())return{};intH=v.size(),W=v[0].size();vectorres(W,T(H,U{}));for(inti=0;i<H;i++){for(intj=0;j<W;j++){res[j][i]=v[i][j];}}returnres;}template<typenameT>vector<T>Rotate(constvector<T>&v,intclockwise=true){usingU=typenameT::value_type;intH=v.size(),W=v[0].size();vectorres(W,T(H,U{}));for(inti=0;i<H;i++){for(intj=0;j<W;j++){if(clockwise){res[W-1-j][i]=v[i][j];}else{res[j][H-1-i]=v[i][j];}}}returnres;}}// namespace Nyaan#line 58 "template/template.hpp"
// bit operation#line 1 "template/bitop.hpp"
namespaceNyaan{__attribute__((target("popcnt")))inlineintpopcnt(constu64&a){return__builtin_popcountll(a);}inlineintlsb(constu64&a){returna?__builtin_ctzll(a):64;}inlineintctz(constu64&a){returna?__builtin_ctzll(a):64;}inlineintmsb(constu64&a){returna?63-__builtin_clzll(a):-1;}template<typenameT>inlineintgbit(constT&a,inti){return(a>>i)&1;}template<typenameT>inlinevoidsbit(T&a,inti,boolb){if(gbit(a,i)!=b)a^=T(1)<<i;}constexprlonglongPW(intn){return1LL<<n;}constexprlonglongMSK(intn){return(1LL<<n)-1;}}// namespace Nyaan#line 61 "template/template.hpp"
// inout#line 1 "template/inout.hpp"
namespaceNyaan{template<typenameT,typenameU>ostream&operator<<(ostream&os,constpair<T,U>&p){os<<p.first<<" "<<p.second;returnos;}template<typenameT,typenameU>istream&operator>>(istream&is,pair<T,U>&p){is>>p.first>>p.second;returnis;}template<typenameT>ostream&operator<<(ostream&os,constvector<T>&v){ints=(int)v.size();for(inti=0;i<s;i++)os<<(i?" ":"")<<v[i];returnos;}template<typenameT>istream&operator>>(istream&is,vector<T>&v){for(auto&x:v)is>>x;returnis;}istream&operator>>(istream&is,__int128_t&x){stringS;is>>S;x=0;intflag=0;for(auto&c:S){if(c=='-'){flag=true;continue;}x*=10;x+=c-'0';}if(flag)x=-x;returnis;}istream&operator>>(istream&is,__uint128_t&x){stringS;is>>S;x=0;for(auto&c:S){x*=10;x+=c-'0';}returnis;}ostream&operator<<(ostream&os,__int128_tx){if(x==0)returnos<<0;if(x<0)os<<'-',x=-x;stringS;while(x)S.push_back('0'+x%10),x/=10;reverse(begin(S),end(S));returnos<<S;}ostream&operator<<(ostream&os,__uint128_tx){if(x==0)returnos<<0;stringS;while(x)S.push_back('0'+x%10),x/=10;reverse(begin(S),end(S));returnos<<S;}voidin(){}template<typenameT,class...U>voidin(T&t,U&...u){cin>>t;in(u...);}voidout(){cout<<"\n";}template<typenameT,class...U,charsep=' '>voidout(constT&t,constU&...u){cout<<t;if(sizeof...(u))cout<<sep;out(u...);}structIoSetupNya{IoSetupNya(){cin.tie(nullptr);ios::sync_with_stdio(false);cout<<fixed<<setprecision(15);cerr<<fixed<<setprecision(7);}}iosetupnya;}// namespace Nyaan#line 64 "template/template.hpp"
// debug#line 1 "template/debug.hpp"
namespaceDebugImpl{template<typenameU,typename=void>structis_specialize:false_type{};template<typenameU>structis_specialize<U,typenameconditional<false,typenameU::iterator,void>::type>:true_type{};template<typenameU>structis_specialize<U,typenameconditional<false,decltype(U::first),void>::type>:true_type{};template<typenameU>structis_specialize<U,enable_if_t<is_integral<U>::value,void>>:true_type{};voiddump(constchar&t){cerr<<t;}voiddump(conststring&t){cerr<<t;}voiddump(constbool&t){cerr<<(t?"true":"false");}voiddump(__int128_tt){if(t==0)cerr<<0;if(t<0)cerr<<'-',t=-t;stringS;while(t)S.push_back('0'+t%10),t/=10;reverse(begin(S),end(S));cerr<<S;}voiddump(__uint128_tt){if(t==0)cerr<<0;stringS;while(t)S.push_back('0'+t%10),t/=10;reverse(begin(S),end(S));cerr<<S;}template<typenameU,enable_if_t<!is_specialize<U>::value,nullptr_t>=nullptr>voiddump(constU&t){cerr<<t;}template<typenameT>voiddump(constT&t,enable_if_t<is_integral<T>::value>*=nullptr){stringres;if(t==Nyaan::inf)res="inf";ifconstexpr(is_signed<T>::value){if(t==-Nyaan::inf)res="-inf";}ifconstexpr(sizeof(T)==8){if(t==Nyaan::infLL)res="inf";ifconstexpr(is_signed<T>::value){if(t==-Nyaan::infLL)res="-inf";}}if(res.empty())res=to_string(t);cerr<<res;}template<typenameT,typenameU>voiddump(constpair<T,U>&);template<typenameT>voiddump(constpair<T*,int>&);template<typenameT>voiddump(constT&t,enable_if_t<!is_void<typenameT::iterator>::value>*=nullptr){cerr<<"[ ";for(autoit=t.begin();it!=t.end();){dump(*it);cerr<<(++it==t.end()?"":", ");}cerr<<" ]";}template<typenameT,typenameU>voiddump(constpair<T,U>&t){cerr<<"( ";dump(t.first);cerr<<", ";dump(t.second);cerr<<" )";}template<typenameT>voiddump(constpair<T*,int>&t){cerr<<"[ ";for(inti=0;i<t.second;i++){dump(t.first[i]);cerr<<(i==t.second-1?"":", ");}cerr<<" ]";}voidtrace(){cerr<<endl;}template<typenameHead,typename...Tail>voidtrace(Head&&head,Tail&&...tail){cerr<<" ";dump(head);if(sizeof...(tail)!=0)cerr<<",";trace(std::forward<Tail>(tail)...);}}// namespace DebugImpl#ifdef NyaanDebug
#define trc(...) \
do { \
cerr << "## " << #__VA_ARGS__ << " = "; \
DebugImpl::trace(__VA_ARGS__); \
} while (0)
#else
#define trc(...) (void(0))
#endif
#ifdef NyaanLocal
#define trc2(...) \
do { \
cerr << "## " << #__VA_ARGS__ << " = "; \
DebugImpl::trace(__VA_ARGS__); \
} while (0)
#else
#define trc2(...) (void(0))
#endif
#line 67 "template/template.hpp"
// macro#line 1 "template/macro.hpp"
#define each(x, v) for (auto&& x : v)
#define each2(x, y, v) for (auto&& [x, y] : v)
#define all(v) (v).begin(), (v).end()
#define rep(i, N) for (long long i = 0; i < (long long)(N); i++)
#define repr(i, N) for (long long i = (long long)(N)-1; i >= 0; i--)
#define rep1(i, N) for (long long i = 1; i <= (long long)(N); i++)
#define repr1(i, N) for (long long i = (N); (long long)(i) > 0; i--)
#define reg(i, a, b) for (long long i = (a); i < (b); i++)
#define regr(i, a, b) for (long long i = (b)-1; i >= (a); i--)
#define fi first
#define se second
#define ini(...) \
int __VA_ARGS__; \
in(__VA_ARGS__)
#define inl(...) \
long long __VA_ARGS__; \
in(__VA_ARGS__)
#define ins(...) \
string __VA_ARGS__; \
in(__VA_ARGS__)
#define in2(s, t) \
for (int i = 0; i < (int)s.size(); i++) { \
in(s[i], t[i]); \
}
#define in3(s, t, u) \
for (int i = 0; i < (int)s.size(); i++) { \
in(s[i], t[i], u[i]); \
}
#define in4(s, t, u, v) \
for (int i = 0; i < (int)s.size(); i++) { \
in(s[i], t[i], u[i], v[i]); \
}
#define die(...) \
do { \
Nyaan::out(__VA_ARGS__); \
return; \
} while (0)
#line 70 "template/template.hpp"
namespaceNyaan{voidsolve();}intmain(){Nyaan::solve();}#line 4 "verify/verify-yosupo-ntt/yosupo-convolution-schoenhage-radix2.test.cpp"
//usingnamespaceNyaan;#line 2 "modint/montgomery-modint.hpp"
template<uint32_tmod>structLazyMontgomeryModInt{usingmint=LazyMontgomeryModInt;usingi32=int32_t;usingu32=uint32_t;usingu64=uint64_t;staticconstexpru32get_r(){u32ret=mod;for(i32i=0;i<4;++i)ret*=2-mod*ret;returnret;}staticconstexpru32r=get_r();staticconstexpru32n2=-u64(mod)%mod;static_assert(mod<(1<<30),"invalid, mod >= 2 ^ 30");static_assert((mod&1)==1,"invalid, mod % 2 == 0");static_assert(r*mod==1,"this code has bugs.");u32a;constexprLazyMontgomeryModInt():a(0){}constexprLazyMontgomeryModInt(constint64_t&b):a(reduce(u64(b%mod+mod)*n2)){};staticconstexpru32reduce(constu64&b){return(b+u64(u32(b)*u32(-r))*mod)>>32;}constexprmint&operator+=(constmint&b){if(i32(a+=b.a-2*mod)<0)a+=2*mod;return*this;}constexprmint&operator-=(constmint&b){if(i32(a-=b.a)<0)a+=2*mod;return*this;}constexprmint&operator*=(constmint&b){a=reduce(u64(a)*b.a);return*this;}constexprmint&operator/=(constmint&b){*this*=b.inverse();return*this;}constexprmintoperator+(constmint&b)const{returnmint(*this)+=b;}constexprmintoperator-(constmint&b)const{returnmint(*this)-=b;}constexprmintoperator*(constmint&b)const{returnmint(*this)*=b;}constexprmintoperator/(constmint&b)const{returnmint(*this)/=b;}constexprbooloperator==(constmint&b)const{return(a>=mod?a-mod:a)==(b.a>=mod?b.a-mod:b.a);}constexprbooloperator!=(constmint&b)const{return(a>=mod?a-mod:a)!=(b.a>=mod?b.a-mod:b.a);}constexprmintoperator-()const{returnmint()-mint(*this);}constexprmintoperator+()const{returnmint(*this);}constexprmintpow(u64n)const{mintret(1),mul(*this);while(n>0){if(n&1)ret*=mul;mul*=mul;n>>=1;}returnret;}constexprmintinverse()const{intx=get(),y=mod,u=1,v=0,t=0,tmp=0;while(y>0){t=x/y;x-=t*y,u-=t*v;tmp=x,x=y,y=tmp;tmp=u,u=v,v=tmp;}returnmint{u};}friendostream&operator<<(ostream&os,constmint&b){returnos<<b.get();}friendistream&operator>>(istream&is,mint&b){int64_tt;is>>t;b=LazyMontgomeryModInt<mod>(t);return(is);}constexpru32get()const{u32ret=reduce(a);returnret>=mod?ret-mod:ret;}staticconstexpru32get_mod(){returnmod;}};#line 2 "ntt/schoenhage-strassen-radix2.hpp"
template<typenameT>structSchoenhage_Strassen_radix2{T*buf=nullptr;voidrot(T*dst,T*src,ints,intd){assert(0<=dandd<2*s);boolf=s<=d;if(s<=d)d-=s;inti=0;if(f){for(;i<s-d;i++)dst[i+d]=-src[i];for(;i<s;i++)dst[i+d-s]=src[i];}else{for(;i<s-d;i++)dst[i+d]=src[i];for(;i<s;i++)dst[i+d-s]=-src[i];}}voidin_add(T*dst,T*src,ints){for(inti=0;i<s;i++)dst[i]+=src[i];}voidin_sub(T*dst,T*src,ints){for(inti=0;i<s;i++)dst[i]-=src[i];}voidcp(T*dst,T*src,ints){memcpy(dst,src,s*sizeof(T));}voidreset(T*dst,ints){fill(dst,dst+s,T());}// R[x] / (1 + x^(2^m)) 上の長さ2^LのFFTvoidfft(T*a,intl,intm){if(l==0)return;intL=1<<l,M=1<<m;assert(M*2>=L);assert(buf!=nullptr);vector<int>dw(l-1);for(inti=0;i<l-1;i++){dw[i]=(1<<(l-2-i))+(1<<(l-1-i))-(1<<(l-1));if(dw[i]<0)dw[i]+=L;if(L==M)dw[i]*=2;if(2*L==M)dw[i]*=4;}for(intd=L;d>>=1;){intw=0;for(ints=0,k=0;;){for(inti=s,j=s+d;i<s+d;++i,++j){T*ai=a+i*M,*aj=a+j*M;rot(buf,aj,M,w);cp(aj,ai,M);in_add(ai,buf,M);in_sub(aj,buf,M);}if((s+=2*d)>=L)break;w+=dw[__builtin_ctz(++k)];if(w>=2*M)w-=2*M;}}}// R[x] / (1 + x^(2^m)) 上の長さ2^LのIFFTvoidifft(T*a,intl,intm){if(l==0)return;intL=1<<l,M=1<<m;assert(M*2>=L);assert(buf!=nullptr);vector<int>dw(l-1);for(inti=0;i<l-1;i++){dw[i]=(1<<(l-2-i))+(1<<(l-1-i))-(1<<(l-1));if(dw[i]<0)dw[i]+=L;if(L==M)dw[i]*=2;if(2*L==M)dw[i]*=4;}for(intd=1;d<L;d*=2){intw=0;for(ints=0,k=0;;){for(inti=s,j=s+d;i<s+d;++i,++j){T*ai=a+i*M,*aj=a+j*M;cp(buf,ai,M);in_add(ai,aj,M);in_sub(buf,aj,M);rot(aj,buf,M,w);}if((s+=2*d)>=L)break;w-=dw[__builtin_ctz(++k)];if(w<0)w+=2*M;}}}// a <- ab / (x^(2^n)+1)intnaive_mul(T*a,T*b,intn){intN=1<<n;reset(buf,N);for(inti=0;i<N;i++){intj=0;for(;j<N-i;j++)buf[i+j]+=a[i]*b[j];for(;j<N;j++)buf[i+j-N]-=a[i]*b[j];}cp(a,buf,N);return0;}// a <- ab / (x^(2^n)+1)intinplace_mul(T*a,T*b,intn){if(n<=5){naive_mul(a,b,n);return0;}intl=(n+1)/2;intm=n/2;intL=1<<l,M=1<<m,N=1<<n;intcnt=0;// R[x] (x^(2^(m+1))-1) R[y] (y^(2^l)-1)vector<T>A(N*2),B(N*2);reset(buf+M,M);for(inti=0,s=0,ds=2*M/L;i<L;i++){// y -> x^{2m/r} ycp(buf,a+i*M,M);rot(A.data()+i*M*2,buf,2*M,s);cp(buf,b+i*M,M);rot(B.data()+i*M*2,buf,2*M,s);s+=ds;if(s>=4*M)s-=4*M;}fft(A.data(),l,m+1);fft(B.data(),l,m+1);for(inti=0;i<L;i++){cnt=inplace_mul(A.data()+i*M*2,B.data()+i*M*2,m+1);}ifft(A.data(),l,m+1);for(inti=0,s=0,ds=2*M/L;i<L;i++){// y -> x^{-2m/r} ycp(buf,A.data()+i*M*2,2*M);rot(A.data()+i*M*2,buf,2*M,s);s-=ds;if(s<0)s+=4*M;}for(inti=0;i<L;i++){for(intj=0;j<M;j++){a[i*M+j]=A[i*M*2+j];if(i==0){a[i*M+j]-=A[(L-1)*M*2+M+j];}else{a[i*M+j]+=A[(i-1)*M*2+M+j];}}}returncnt+l;}// a <- ab / (x^(2^n)-1)intinplace_mul2(T*a,T*b,intn){if(n<=5){naive_mul(a,b,n);return0;}intl=(n+1)/2;intm=n/2;intL=1<<l,M=1<<m,N=1<<n;intcnt=0;// R[x] (x^(2^(m+1))-1) R[y] (y^(2^l)-1)vector<T>A(N*2),B(N*2);for(inti=0;i<L;i++){cp(A.data()+i*M*2,a+i*M,M);cp(B.data()+i*M*2,b+i*M,M);}fft(A.data(),l,m+1);fft(B.data(),l,m+1);for(inti=0;i<L;i++){cnt=inplace_mul(A.data()+i*M*2,B.data()+i*M*2,m+1);}ifft(A.data(),l,m+1);for(inti=0;i<L;i++){for(intj=0;j<M;j++){a[i*M+j]=A[i*M*2+j];a[i*M+j]+=A[(i?i-1:L-1)*M*2+M+j];}}returncnt+l;}pair<vector<T>,int>multiply(constvector<T>&a,constvector<T>&b){intL=a.size()+b.size()-1;intM=1,m=0;while(M<L)M*=2,m++;buf=newT[M];vector<T>s(M),t(M);for(inti=0;i<(int)a.size();i++)s[i]=a[i];for(inti=0;i<(int)b.size();i++)t[i]=b[i];intcnt=inplace_mul2(s.data(),t.data(),m);vector<T>u(L);for(inti=0;i<L;i++)u[i]=s[i];delete[]buf;returnmake_pair(u,cnt);}};/**
* @brief Schönhage-Strassen Algorithm(radix-2)
*/#line 9 "verify/verify-yosupo-ntt/yosupo-convolution-schoenhage-radix2.test.cpp"
usingmint=LazyMontgomeryModInt<1000000007>;usingvm=V<mint>;Schoenhage_Strassen_radix2<mint>ss;/*
#include "misc/timer.hpp"
void calc() {
int N = TEN(5) * 5;
vm a(N), b(N);
int e = 1;
each(x, a) x = e, ++e;
each(x, b) x = e, ++e;
Timer timer;
auto c = ss.multiply(a, b);
cerr << c.first.size() << " " << timer.elapsed() << endl;
}
void test() {
for (int n = 1, m = 1; n < 100; n += 2, m += 2) {
vm a(n), b(m);
int e = 1;
each(x, a) x = e, e += 1;
// each(x, b) x = e, e += 1;
b = a;
auto [c, d] = ss.multiply(a, b);
mint inv = mint(1 << d).inverse();
each(x, c) x *= inv;
vm C(n + m - 1);
rep(i, n) rep(j, m) C[i + j] += a[i] * b[j];
assert(C == c);
}
}
*/voidNyaan::solve(){// test();// calc();ini(N,M);vma(N),b(M);in(a,b);auto[c,d]=ss.multiply(a,b);mintinv=mint(1<<d).inverse();each(x,c)x*=inv;out(c);}