結果
問題 |
No.1492 01文字列と転倒
|
ユーザー |
![]() |
提出日時 | 2022-12-03 18:08:18 |
言語 | PyPy3 (7.3.15) |
結果 |
TLE
|
実行時間 | - |
コード長 | 648 bytes |
コンパイル時間 | 207 ms |
コンパイル使用メモリ | 82,432 KB |
実行使用メモリ | 97,152 KB |
最終ジャッジ日時 | 2024-10-10 20:50:30 |
合計ジャッジ時間 | 5,992 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | TLE * 1 -- * 21 |
ソースコード
N, M = map(int, input().split()) dp = [[[0]*(N**2+1) for _ in range(N+1)] for _ in range(2)] dp[0][0][0] = 1 for i in range(1,2*N+1): for j in range(N+1): for k in range(N**2+1): dp[i%2][j][k] = 0 for j in range(min(i+1,N+1)): for k in range(N**2+1): if j+1<=N and j+1<=i-j-1: dp[i%2][j+1][k] += dp[(i-1)%2][j][k] dp[i%2][j+1][k] %= M if k+j<=N**2 and j<=i-j: dp[i%2][j][k+j] += dp[(i-1)%2][j][k] dp[i%2][j][k+j] %= M for i in range(N**2+1): if N%2==1: print(dp[-1][-1][i]) else: print(dp[0][-1][i])