結果
問題 | No.288 貯金箱の仕事 |
ユーザー |
![]() |
提出日時 | 2020-03-31 14:04:07 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 687 ms / 2,000 ms |
コード長 | 605 bytes |
コンパイル時間 | 229 ms |
コンパイル使用メモリ | 82,280 KB |
実行使用メモリ | 64,212 KB |
最終ジャッジ日時 | 2024-06-24 11:54:15 |
合計ジャッジ時間 | 15,066 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 53 |
ソースコード
#!/usr/bin/ python3.8 import sys read = sys.stdin.buffer.read readline = sys.stdin.buffer.readline readlines = sys.stdin.buffer.readlines N, M = map(int, readline().split()) A = tuple(map(int, readline().split())) K = tuple(map(int, readline().split())) M = sum(a * k for a, k in zip(A, K)) - M if M < 0: print(-1) exit() U = 260000 INF = 10 ** 18 dp = [INF] * U dp[0] = 0 for a in A: for i in range(a, U): x = dp[i - a] + 1 if dp[i] > x: dp[i] = x n = A[-1] k = max(0, (M - U) // n + 1) M -= k * n if dp[M] > 10 ** 17: print(-1) else: print(dp[M] + k)