#define PROBLEM "https://judge.yosupo.jp/problem/aplusb"
//#include"../../template/template.hpp"//#include"../../atcoder/internal_math.hpp"
#include"../../misc/rng.hpp"
#include"../../modint/arbitrary-modint.hpp"
#include"../../modint/arbitrary-montgomery-modint.hpp"usingnamespaceNyaan;template<typenamemint>voidtest(intmod,inttestcases){assert(0<modandmod<=(1<<30)-1);mint::set_mod(mod);rep(t,testcases){inta=randint(0,mod);if(rng()%10==0)a=(mod-1)%mod;if(rng()%10==0)a=0;mintA=a;assert(A.get()==a);intb=randint(0,mod);if(rng()%10==0)b=(mod-1)%mod;if(rng()%10==0)b=0;mintB=b;assert(B.get()==b);intc=(a+b)%mod;mintC=A+B;assert(C.get()==c);intd=(a+mod-b)%mod;mintD=A-B;assert(D.get()==d);inte=(1LL*a*b)%mod;mintE=A*B;assert(E.get()==e);// 逆元 : f * g = 1intf,g=-1;do{f=randint(0,mod);auto[gc,invf]=atcoder::internal::inv_gcd(f,mod);g=invf;}while(1LL*f*g%mod!=1LL%mod);mintF=f;mintG=F.inverse();assert(F.get()==f);assert(G.get()==g);assert(F*G==1);inth=1LL*e*g%mod;mintH=E/F;assert(H.get()==h);inti=randint(0,mod);if(rng()%10==0)i=(mod-1)%mod;if(rng()%10==0)i=0;longlongex=randint(0,TEN(18));if(rng()%10==0)ex=randint(0,2);intj=1%mod;{inti2=i;longlonge2=ex;while(e2){if(e2&1)j=1LL*j*i2%mod;i2=1LL*i2*i2%mod;e2>>=1;}}mintI=i;mintJ=I.pow(ex);assert(I.get()==i);assert(J.get()==j);intk=(mod-a)%mod;mintK=-A;assert(K.get()==k);}}voidtest_wrapper(intmod,inttestcases){usingmint1=ArbitraryModInt;usingmint2=ArbitraryLazyMontgomeryModInt<96229631>;test<mint1>(mod,testcases);if(mod%2==1)test<mint2>(mod,testcases);}voidtest_all(){{usingmint3=ArbitraryModIntBase<0>;usingmint5=ArbitraryModIntBase<1>;mint3::set_mod(3);mint5::set_mod(5);assert(mint3::get_mod()==3);assert(mint5::get_mod()==5);}{usingmint3=ArbitraryLazyMontgomeryModInt<0>;usingmint5=ArbitraryLazyMontgomeryModInt<1>;mint3::set_mod(3);mint5::set_mod(5);assert(mint3::get_mod()==3);assert(mint5::get_mod()==5);}intmod_max=(1LL<<30)-1;rep1(m,10)test_wrapper(m,10000);test_wrapper(998244353,10000);test_wrapper(1000000007,10000);rep(t,10){test_wrapper(mod_max-t,10000);}rep(t,1000){intmod=randint(1,mod_max+1);test_wrapper(mod,1000);}cerr<<"OK"<<endl;}voidNyaan::solve(){test_all();inta,b;cin>>a>>b;cout<<a+b<<"\n";}
#line 1 "verify/verify-unit-test/arbitrary-modint.test.cpp"
#define PROBLEM "https://judge.yosupo.jp/problem/aplusb"
//#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 3 "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 : void(T&), mod を取る操作// T : 整数型のときはオーバーフローに注意するtemplate<typenameT,typenameF>TPower(Ta,longlongn,constT&I,F&&f){static_assert(std::is_invocable_r_v<void,F&,T&>,"Power callback must be callable as void(T&)");Tres=I;for(;n;std::invoke(f,a=a*a),n>>=1){if(n&1)std::invoke(f,res=res*a);}returnres;}// T : 整数型のときはオーバーフローに注意するtemplate<typenameT>TPower(Ta,longlongn,constT&I=T{1}){autono_op=[](T&)->void{};returnPower(a,n,I,no_op);}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-unit-test/arbitrary-modint.test.cpp"
//#line 1 "atcoder/internal_math.hpp"
#line 5 "atcoder/internal_math.hpp"
#ifdef _MSC_VER
#include<intrin.h>
#endif
namespaceatcoder{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 atcoder#line 2 "misc/rng.hpp"
#line 7 "misc/rng.hpp"
usingnamespacestd;#line 2 "internal/internal-seed.hpp"
#line 4 "internal/internal-seed.hpp"
usingnamespacestd;namespacenyaan_internal{unsignedlonglongnon_deterministic_seed(){unsignedlonglongm=chrono::duration_cast<chrono::nanoseconds>(chrono::high_resolution_clock::now().time_since_epoch()).count();m^=9845834732710364265uLL;m^=m<<24,m^=m>>31,m^=m<<35;returnm;}unsignedlonglongdeterministic_seed(){return88172645463325252UL;}// 64 bit の seed 値を生成 (手元では seed 固定)// 連続で呼び出すと同じ値が何度も返ってくるので注意// #define RANDOMIZED_SEED するとシードがランダムになるunsignedlonglongseed(){#if defined(NyaanLocal) && !defined(RANDOMIZED_SEED)
returndeterministic_seed();#else
returnnon_deterministic_seed();#endif
}}// namespace nyaan_internal#line 10 "misc/rng.hpp"
namespacemy_rand{usingi64=longlong;usingu64=unsignedlonglong;// [0, 2^64 - 1)u64rng(){staticu64_x=nyaan_internal::seed();return_x^=_x<<7,_x^=_x>>9;}// [l, r]i64rng(i64l,i64r){assert(l<=r);returnl+rng()%u64(r-l+1);}// [l, r)i64randint(i64l,i64r){assert(l<r);returnl+rng()%u64(r-l);}// choose n numbers from [l, r) without overlappingvector<i64>randset(i64l,i64r,i64n){assert(l<=r&&n<=r-l);unordered_set<i64>s;for(i64i=n;i;--i){i64m=randint(l,r+1-i);if(s.find(m)!=s.end())m=r-i;s.insert(m);}vector<i64>ret;for(auto&x:s)ret.push_back(x);sort(begin(ret),end(ret));returnret;}// [0.0, 1.0)doublernd(){returnrng()*5.42101086242752217004e-20;}// [l, r)doublernd(doublel,doubler){assert(l<r);returnl+rnd()*(r-l);}template<typenameT>voidrandshf(vector<T>&v){intn=v.size();for(inti=1;i<n;i++)swap(v[i],v[randint(0,i+1)]);}}// namespace my_randusingmy_rand::randint;usingmy_rand::randset;usingmy_rand::randshf;usingmy_rand::rnd;usingmy_rand::rng;#line 2 "modint/arbitrary-modint.hpp"
#line 2 "modint/barrett-reduction.hpp"
#line 4 "modint/barrett-reduction.hpp"
usingnamespacestd;structBarrett{usingu32=unsignedint;usingi64=longlong;usingu64=unsignedlonglong;u32m;u64im;Barrett():m(),im(){}Barrett(intn):m(n),im(u64(-1)/m+1){}constexprinlinei64quo(u64n){u64x=u64((__uint128_t(n)*im)>>64);u32r=n-x*m;returnm<=r?x-1:x;}constexprinlinei64rem(u64n){u64x=u64((__uint128_t(n)*im)>>64);u32r=n-x*m;returnm<=r?r+m:r;}constexprinlinepair<i64,int>quorem(u64n){u64x=u64((__uint128_t(n)*im)>>64);u32r=n-x*m;if(m<=r)return{x-1,r+m};return{x,r};}constexprinlinei64pow(u64n,i64p){u32a=rem(n),r=m==1?0:1;while(p){if(p&1)r=rem(u64(r)*a);a=rem(u64(a)*a);p>>=1;}returnr;}};#line 4 "modint/arbitrary-modint.hpp"
template<intid>structArbitraryModIntBase{intx;ArbitraryModIntBase():x(0){}ArbitraryModIntBase(int64_ty){intz=y%get_mod();if(z<0)z+=get_mod();x=z;}ArbitraryModIntBase&operator+=(constArbitraryModIntBase&p){if((x+=p.x)>=get_mod())x-=get_mod();return*this;}ArbitraryModIntBase&operator-=(constArbitraryModIntBase&p){if((x+=get_mod()-p.x)>=get_mod())x-=get_mod();return*this;}ArbitraryModIntBase&operator*=(constArbitraryModIntBase&p){x=rem((unsignedlonglong)x*p.x);return*this;}ArbitraryModIntBase&operator/=(constArbitraryModIntBase&p){*this*=p.inverse();return*this;}ArbitraryModIntBaseoperator-()const{returnArbitraryModIntBase(-x);}ArbitraryModIntBaseoperator+()const{return*this;}ArbitraryModIntBaseoperator+(constArbitraryModIntBase&p)const{returnArbitraryModIntBase(*this)+=p;}ArbitraryModIntBaseoperator-(constArbitraryModIntBase&p)const{returnArbitraryModIntBase(*this)-=p;}ArbitraryModIntBaseoperator*(constArbitraryModIntBase&p)const{returnArbitraryModIntBase(*this)*=p;}ArbitraryModIntBaseoperator/(constArbitraryModIntBase&p)const{returnArbitraryModIntBase(*this)/=p;}booloperator==(constArbitraryModIntBase&p)const{returnx==p.x;}booloperator!=(constArbitraryModIntBase&p)const{returnx!=p.x;}ArbitraryModIntBaseinverse()const{inta=x,b=get_mod(),u=1,v=0,t;while(b>0){t=a/b;swap(a-=t*b,b);swap(u-=t*v,v);}returnArbitraryModIntBase(u);}ArbitraryModIntBasepow(int64_tn)const{ArbitraryModIntBaseret(1),mul(x);while(n>0){if(n&1)ret*=mul;mul*=mul;n>>=1;}returnret;}friendostream&operator<<(ostream&os,constArbitraryModIntBase&p){returnos<<p.x;}friendistream&operator>>(istream&is,ArbitraryModIntBase&a){int64_tt;is>>t;a=ArbitraryModIntBase(t);return(is);}intget()const{returnx;}inlineunsignedintrem(unsignedlonglongp){returnbarrett().rem(p);}staticinlineBarrett&barrett(){staticBarrettb;returnb;}staticinlineint&get_mod(){staticintmod=0;returnmod;}staticvoidset_mod(intmd){assert(0<md&&md<=(1LL<<30)-1);get_mod()=md;barrett()=Barrett(md);}};usingArbitraryModInt=ArbitraryModIntBase<-1>;/**
* @brief modint (2^{30} 未満の任意 mod 用)
*/#line 2 "modint/arbitrary-montgomery-modint.hpp"
#line 4 "modint/arbitrary-montgomery-modint.hpp"
usingnamespacestd;template<typenameInt,typenameUInt,typenameLong,typenameULong,intid>structArbitraryLazyMontgomeryModIntBase{usingmint=ArbitraryLazyMontgomeryModIntBase;inlinestaticUIntmod;inlinestaticUIntr;inlinestaticUIntn2;staticconstexprintbit_length=sizeof(UInt)*8;staticUIntget_r(){UIntret=mod;while(mod*ret!=1)ret*=UInt(2)-mod*ret;returnret;}staticvoidset_mod(UIntm){assert(m<(UInt(1u)<<(bit_length-2)));assert((m&1)==1);mod=m,n2=-ULong(m)%m,r=get_r();}UInta;ArbitraryLazyMontgomeryModIntBase():a(0){}ArbitraryLazyMontgomeryModIntBase(constLong&b):a(reduce(ULong(b%mod+mod)*n2)){};staticUIntreduce(constULong&b){return(b+ULong(UInt(b)*UInt(-r))*mod)>>bit_length;}mint&operator+=(constmint&b){if(Int(a+=b.a-2*mod)<0)a+=2*mod;return*this;}mint&operator-=(constmint&b){if(Int(a-=b.a)<0)a+=2*mod;return*this;}mint&operator*=(constmint&b){a=reduce(ULong(a)*b.a);return*this;}mint&operator/=(constmint&b){*this*=b.inverse();return*this;}mintoperator+(constmint&b)const{returnmint(*this)+=b;}mintoperator-(constmint&b)const{returnmint(*this)-=b;}mintoperator*(constmint&b)const{returnmint(*this)*=b;}mintoperator/(constmint&b)const{returnmint(*this)/=b;}booloperator==(constmint&b)const{return(a>=mod?a-mod:a)==(b.a>=mod?b.a-mod:b.a);}booloperator!=(constmint&b)const{return(a>=mod?a-mod:a)!=(b.a>=mod?b.a-mod:b.a);}mintoperator-()const{returnmint(0)-mint(*this);}mintoperator+()const{returnmint(*this);}mintpow(ULongn)const{mintret(1),mul(*this);while(n>0){if(n&1)ret*=mul;mul*=mul,n>>=1;}returnret;}friendostream&operator<<(ostream&os,constmint&b){returnos<<b.get();}friendistream&operator>>(istream&is,mint&b){Longt;is>>t;b=ArbitraryLazyMontgomeryModIntBase(t);return(is);}mintinverse()const{Intx=get(),y=get_mod(),u=1,v=0;while(y>0){Intt=x/y;swap(x-=t*y,y);swap(u-=t*v,v);}returnmint{u};}UIntget()const{UIntret=reduce(a);returnret>=mod?ret-mod:ret;}staticUIntget_mod(){returnmod;}};// id に適当な乱数を割り当てて使うtemplate<intid>usingArbitraryLazyMontgomeryModInt=ArbitraryLazyMontgomeryModIntBase<int,unsignedint,longlong,unsignedlonglong,id>;template<intid>usingArbitraryLazyMontgomeryModInt64bit=ArbitraryLazyMontgomeryModIntBase<longlong,unsignedlonglong,__int128_t,__uint128_t,id>;#line 9 "verify/verify-unit-test/arbitrary-modint.test.cpp"
usingnamespaceNyaan;template<typenamemint>voidtest(intmod,inttestcases){assert(0<modandmod<=(1<<30)-1);mint::set_mod(mod);rep(t,testcases){inta=randint(0,mod);if(rng()%10==0)a=(mod-1)%mod;if(rng()%10==0)a=0;mintA=a;assert(A.get()==a);intb=randint(0,mod);if(rng()%10==0)b=(mod-1)%mod;if(rng()%10==0)b=0;mintB=b;assert(B.get()==b);intc=(a+b)%mod;mintC=A+B;assert(C.get()==c);intd=(a+mod-b)%mod;mintD=A-B;assert(D.get()==d);inte=(1LL*a*b)%mod;mintE=A*B;assert(E.get()==e);// 逆元 : f * g = 1intf,g=-1;do{f=randint(0,mod);auto[gc,invf]=atcoder::internal::inv_gcd(f,mod);g=invf;}while(1LL*f*g%mod!=1LL%mod);mintF=f;mintG=F.inverse();assert(F.get()==f);assert(G.get()==g);assert(F*G==1);inth=1LL*e*g%mod;mintH=E/F;assert(H.get()==h);inti=randint(0,mod);if(rng()%10==0)i=(mod-1)%mod;if(rng()%10==0)i=0;longlongex=randint(0,TEN(18));if(rng()%10==0)ex=randint(0,2);intj=1%mod;{inti2=i;longlonge2=ex;while(e2){if(e2&1)j=1LL*j*i2%mod;i2=1LL*i2*i2%mod;e2>>=1;}}mintI=i;mintJ=I.pow(ex);assert(I.get()==i);assert(J.get()==j);intk=(mod-a)%mod;mintK=-A;assert(K.get()==k);}}voidtest_wrapper(intmod,inttestcases){usingmint1=ArbitraryModInt;usingmint2=ArbitraryLazyMontgomeryModInt<96229631>;test<mint1>(mod,testcases);if(mod%2==1)test<mint2>(mod,testcases);}voidtest_all(){{usingmint3=ArbitraryModIntBase<0>;usingmint5=ArbitraryModIntBase<1>;mint3::set_mod(3);mint5::set_mod(5);assert(mint3::get_mod()==3);assert(mint5::get_mod()==5);}{usingmint3=ArbitraryLazyMontgomeryModInt<0>;usingmint5=ArbitraryLazyMontgomeryModInt<1>;mint3::set_mod(3);mint5::set_mod(5);assert(mint3::get_mod()==3);assert(mint5::get_mod()==5);}intmod_max=(1LL<<30)-1;rep1(m,10)test_wrapper(m,10000);test_wrapper(998244353,10000);test_wrapper(1000000007,10000);rep(t,10){test_wrapper(mod_max-t,10000);}rep(t,1000){intmod=randint(1,mod_max+1);test_wrapper(mod,1000);}cerr<<"OK"<<endl;}voidNyaan::solve(){test_all();inta,b;cin>>a>>b;cout<<a+b<<"\n";}