#include using namespace std; //入力が必ず-mod //modが入力で与えられる場合. struct dynamic_modint{ //mod変更が可能 最初にsetmod必須 idxで複数個所持が可能. private: static int mod; public: int v; static constexpr long long getmod(){return mod;} static void setmod(int m){ assert(m > 0); mod = m; } dynamic_modint():v(0){} template dynamic_modint(T a):v(a){if(v < 0) v += mod;} long long val()const{return v;} dynamic_modint &operator=(const dynamic_modint &b) = default; dynamic_modint &operator+()const{return (*this);} dynamic_modint operator-()const{return dynamic_modint(0)-(*this);} dynamic_modint operator+(const dynamic_modint b)const{return dynamic_modint(v)+=b;} dynamic_modint operator-(const dynamic_modint b)const{return dynamic_modint(v)-=b;} dynamic_modint operator*(const dynamic_modint b)const{return dynamic_modint(v)*=b;} dynamic_modint operator/(const dynamic_modint b)const{return dynamic_modint(v)/=b;} dynamic_modint &operator+=(const dynamic_modint b){ v += b.v; if(v >= mod) v -= mod; return *this; } dynamic_modint &operator-=(const dynamic_modint b){ v -= b.v; if(v < 0) v += mod; return *this; } dynamic_modint &operator*=(const dynamic_modint b){v = (long long)v*b.v%mod; return *this;} dynamic_modint &operator/=(dynamic_modint b){ //b!=0 mod素数が必須. assert(b.v != 0); (*this) *= b.pow(mod-2); return *this; } dynamic_modint pow(long long n)const{ dynamic_modint ret = 1,p = v; if(n < 0) p = p.inv(),n = -n; while(n){if(n&1) ret *= p; p *= p,n >>= 1;} return ret; } dynamic_modint inv()const{return pow(mod-2);} //素数mod必須. dynamic_modint &operator++(){*this += 1; return *this;} dynamic_modint &operator--(){*this -= 1; return *this;} dynamic_modint operator++(int){dynamic_modint ret = *this; *this += 1; return ret;} dynamic_modint operator--(int){dynamic_modint ret = *this; *this -= 1; return ret;} friend bool operator==(const dynamic_modint a,const dynamic_modint b){return a.v==b.v;} friend bool operator!=(const dynamic_modint a,const dynamic_modint b){return a.v!=b.v;} friend bool operator<(const dynamic_modint a,const dynamic_modint b){return a.v=(const dynamic_modint a,const dynamic_modint b){return a.v>=b.v;} friend bool operator>(const dynamic_modint a,const dynamic_modint b){return a.v>b.v;} friend ostream &operator<<(ostream &os,const dynamic_modint a){return os<>(istream &is,dynamic_modint &a){ //入力はmodをとってくれる. long long x; is >> x; x %= mod; a = dynamic_modint(x); return is; } }; template int dynamic_modint::mod=998244353; using mint = dynamic_modint<0>; int main(){ ios_base::sync_with_stdio(false); cin.tie(nullptr); long long mod; cin >> mod; mint::setmod(mod); vector inv(mod); inv.at(1) = 1; for(int i=2; i