結果
問題 |
No.1964 sum = length
|
ユーザー |
|
提出日時 | 2022-06-03 22:50:35 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,039 bytes |
コンパイル時間 | 1,746 ms |
コンパイル使用メモリ | 174,824 KB |
実行使用メモリ | 325,120 KB |
最終ジャッジ日時 | 2024-09-21 03:07:06 |
合計ジャッジ時間 | 19,421 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 11 WA * 29 |
ソースコード
#include <bits/stdc++.h> using namespace std; #define rep(i,n) for(int i=0; i<(n); i++) #define INF ((1LL<<62)-(1LL<<31)) #define all(a) (a).begin(),(a).end() #define rall(a) (a).rbegin(),(a).rend() typedef long long ll; typedef pair<ll,ll> pl; const ll mod=998244353; int main() { ll n; cin >> n; ll len=5*n; vector<vector<vector<ll>>> dp(n,vector<vector<ll>> (len,vector<ll> (n,0))); for(int i=1;i<len;i++) dp[0][i][i/10]=1; for(int i=0;i<n-1;i++) { rep(j,len) rep(k,n) { for(int l=1;l<=1000;l*=10) { if(j+l<len&&k+l/10<n) dp[i+1][j+l][k+l/10]=(dp[i+1][j+l][k+l/10]+dp[i][j][k])%mod; if(j+l*10<len&&k+l/10<n) dp[i+1][j+l*10][k+l/10]=(dp[i+1][j+l*10][k+l/10]+(-dp[i][j][k]+2*mod)%mod)%mod; } } rep(j,n) for(int k=1;k<len;k++) dp[i+1][k][j]=(dp[i+1][k][j]+dp[i+1][k-1][j])%mod; } ll ans=0; for(int i=0;i<n;i++) { if(2*n-1+i<len) ans=(ans+dp[n-1][2*n-1+i][i])%mod; } cout << ans << endl; return 0; }