結果
問題 |
No.1457 ツブ消ししとるなHard
|
ユーザー |
|
提出日時 | 2022-06-03 07:50:07 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 933 bytes |
コンパイル時間 | 229 ms |
コンパイル使用メモリ | 82,560 KB |
実行使用メモリ | 95,232 KB |
最終ジャッジ日時 | 2024-09-21 02:15:43 |
合計ジャッジ時間 | 2,750 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 WA * 1 |
other | AC * 9 WA * 8 |
ソースコード
N,M,X,Y,Z = map(int,input().split()) A = list(map(int,input().split())) l = [] count = 0 s = 0 for a in A: if a >= X: count += 1 s += a - Z elif a > Y: l.append(a - Z) n = len(l) import sys if count > M: print('Handicapped') exit() if count == M: if s == 0: print(1) else: print(0) exit() C = 2500 + 10 base = 2500 + 5 dp = [[0] * (2 * C) for _ in range(M - count + 1)] dp[0][base + s] = 1 for i in range(n): a = l[i] nx = [[0] * (2 * C) for _ in range(M - count + 1)] for j in range(M - count): u = dp[j] v = nx[j + 1] for k in range(2 * C): if 0 <= k + a < 2 * C: v[k + a] += u[k] for j in range(1 + M - count): u = dp[j] v = nx[j] for k in range(2 * C): v[k] += u[k] dp = nx ans = 0 for j in range(M - count + 1): ans += dp[j][base] print(ans)