結果
問題 |
No.1457 ツブ消ししとるなHard
|
ユーザー |
![]() |
提出日時 | 2022-05-31 10:39:11 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 152 ms / 2,000 ms |
コード長 | 807 bytes |
コンパイル時間 | 254 ms |
コンパイル使用メモリ | 82,560 KB |
実行使用メモリ | 115,176 KB |
最終ジャッジ日時 | 2024-09-21 01:10:56 |
合計ジャッジ時間 | 2,815 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 17 |
ソースコード
n,m,x,y,z=map(int,input().split()) a=list(map(int,input().split())) cnt=[1 for i in range(n) if a[i] >= x] a.sort(reverse=True) dp=[[[0]*2501 for j in range(m+1)] for i in range(n+1)] dp[0][0][0]=1 if len(cnt) > m : print('Handicapped') exit() for i in range(n): for j in range(m+1): for k in range(2501): if dp[i][j][k] == 0: continue if a[i] >= x: dp[i+1][j+1][k+a[i]] += dp[i][j][k] continue dp[i+1][j][k] += dp[i][j][k]#a[i]>=xのときは強制なのでこれをやってはだめ if a[i] <= y: continue if j+1 <= m: dp[i+1][j+1][k+a[i]] += dp[i][j][k] ans=0 for j in range(1,m+1): ans+=dp[-1][j][j*z] print(ans)