結果
問題 | No.2468 Mercurialist |
ユーザー |
|
提出日時 | 2023-10-02 18:11:13 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 123 ms / 2,000 ms |
コード長 | 1,940 bytes |
コンパイル時間 | 1,578 ms |
コンパイル使用メモリ | 199,236 KB |
最終ジャッジ日時 | 2025-02-17 04:02:30 |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 30 |
ソースコード
#include <bits/stdc++.h> using namespace std; using ll = long long; #define rep(i,n) for(ll i=0;i<n;i++) constexpr ll MOD = 998244353; const int MAX_N = 300300; vector<ll> fac(MAX_N), finv(MAX_N), inv(MAX_N); void init(){ fac[0] = fac[1] = 1; finv[0] = finv[1] = 1; inv[1] = 1; for(int i=2;i<MAX_N;i++){ fac[i] = fac[i-1] * i % MOD; inv[i] = MOD - inv[MOD%i] * (MOD/i) % MOD; finv[i] = finv[i-1] * inv[i] % MOD; } } ll mcomb(int n, int k){ if(n<k) return 0; if(n<0 || k<0) return 0; return fac[n] * (finv[k] * finv[n-k] % MOD) % MOD; } ll mperm(int n,int k){ if(n<k)return 0; if(n<0||k<0)return 0; return fac[n] * (finv[n-k] % MOD) % MOD; } ll modpow(ll a,ll n,ll mod=MOD){ a%=mod; if(n==0)return 1; if(n==1)return a%mod; if(n%2==0){ ll res=modpow(a,n/2,mod); return (res*res)%mod; } else{ return (a*modpow(a,n-1,mod))%MOD; } } ll sqrtz(ll N){ ll n=sqrt(N); for(ll i=max(1ll,n-5);i<=n+5;i++){ if(i*i>N)return i-1; } return n; } bool DEB=0; int main(){ ll X,Y,Z,K; cin>>X>>Y>>Z>>K; ll D=X+Y+Z; ll an=0; init(); for(ll d=1;d<=D;d++){ ll zanD=D-d; if(DEB)cout<<d<<" "<<zanD<<endl; if(zanD<X-1)continue; ll res=1; res=X; res*=mperm(zanD,X-1); res%=MOD; if(DEB)cout<<1<<":"<<res<<endl; ll okY=zanD+1+K-X; ll Ynum=max(d-K,0ll); ll inY=min(Y,Ynum); if(DEB)cout<<"iY"<<inY<<" "<<Ynum<<endl; if(inY>0){ res*=modpow(okY,inY); res%=MOD; } if(DEB)cout<<2<<":"<<res<<endl; if(Y>inY){ res*=mperm(D-X-inY,Y-inY); res%=MOD; } if(DEB)cout<<3<<":"<<res<<endl; res*=fac[Z]; res%=MOD; an+=res; an%=MOD; } an*=finv[D]; an%=MOD; cout<<an<<endl; }