結果
問題 |
No.3215 Make K types-able
|
ユーザー |
![]() |
提出日時 | 2025-08-04 22:08:08 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 997 ms / 4,000 ms |
コード長 | 531 bytes |
コンパイル時間 | 549 ms |
コンパイル使用メモリ | 82,688 KB |
実行使用メモリ | 112,964 KB |
最終ジャッジ日時 | 2025-09-04 14:35:46 |
合計ジャッジ時間 | 13,158 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 10 |
ソースコード
Q=int(input()) N=2*10**5 dp=[[0]*12 for i in range(N)] dp[0][0]=1 dp[0][1]=1 u=[0]*N u[0]=1 mod=998244353 mod2=mod-1 for i in range(1,N): for a in range(11): for b in range(11): if a+b>10: break w=a+b if w>0: w+=1 dp[i][a+b]+=dp[i-1][a]*dp[i-1][b] dp[i][a+b]%=mod u[i]=u[i-1]*2+1 u[i]%=mod2 count=u[i-1]*2 count%=mod2 dp[i][0]+=pow(2,count,mod) dp[i][0]%=mod for _ in range(Q): N,K=map(int,input().split()) result=dp[N-1][K-1] result%=mod print(result)