結果
問題 |
No.1457 ツブ消ししとるなHard
|
ユーザー |
|
提出日時 | 2022-06-03 07:51:31 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 194 ms / 2,000 ms |
コード長 | 961 bytes |
コンパイル時間 | 203 ms |
コンパイル使用メモリ | 82,372 KB |
実行使用メモリ | 95,264 KB |
最終ジャッジ日時 | 2024-09-21 02:15:46 |
合計ジャッジ時間 | 2,702 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 17 |
ソースコード
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] if count == 0: ans -= 1 print(ans)