結果

問題 No.1492 01文字列と転倒
ユーザー penguinmanpenguinman
提出日時 2021-04-26 00:49:56
言語 PyPy3
(7.3.15)
結果
RE  
実行時間 -
コード長 526 bytes
コンパイル時間 265 ms
コンパイル使用メモリ 87,192 KB
実行使用メモリ 96,924 KB
最終ジャッジ日時 2023-09-17 14:20:36
合計ジャッジ時間 5,403 ms
ジャッジサーバーID
(参考情報)
judge13 / judge11
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 RE -
testcase_01 RE -
testcase_02 RE -
testcase_03 RE -
testcase_04 RE -
testcase_05 RE -
testcase_06 RE -
testcase_07 RE -
testcase_08 RE -
testcase_09 RE -
testcase_10 RE -
testcase_11 RE -
testcase_12 RE -
testcase_13 RE -
testcase_14 RE -
testcase_15 RE -
testcase_16 RE -
testcase_17 RE -
testcase_18 RE -
testcase_19 RE -
testcase_20 RE -
testcase_21 RE -
testcase_22 RE -
testcase_23 RE -
権限があれば一括ダウンロードができます

ソースコード

diff #

N, M = map(int, input().split())
dp = [[[0 for i in range(N*N+1)]for j in range(N+1)]for k in range(2)]
dp[0][0][0] = 1
for i in range(N):
    for j in range(min(N+1,i+2)):
        for k in range(min(N*(N-1)/2+1, (i+2)*(i+1)/2+1)):
            f = (i+1)&1
            g = 1-f
            dp[f][j][k] = 0
            if 0 < j:
                dp[f][j][k] += dp[f][j-1][k]
            if j <= i and j <= k:
                dp[f][j][k] += dp[g][j][k-j]
            dp[f][j][k] %= M
for i in range(N*N+1):
    print(dp[N%2][N][i])
0