結果
問題 | No.472 平均順位 |
ユーザー |
|
提出日時 | 2023-11-02 00:11:36 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,314 ms / 2,000 ms |
コード長 | 561 bytes |
コンパイル時間 | 191 ms |
コンパイル使用メモリ | 82,560 KB |
実行使用メモリ | 80,128 KB |
最終ジャッジ日時 | 2024-09-25 18:03:04 |
合計ジャッジ時間 | 7,774 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 16 |
ソースコード
n, p = map(int, input().split()) INF = 10**18 DP = [INF for _ in range(p + 1)] DP[0] = 0 for _ in range(n): a, b, c = map(int, input().split()) NDP = [INF for _ in range(p + 1)] for i in range(p + 1): if DP[i] != INF: NDP[i] = min(NDP[i], DP[i] + a) if i + 1 <= p: NDP[i + 1] = min(NDP[i + 1], DP[i] + b) if i + 2 <= p: NDP[i + 2] = min(NDP[i + 2], DP[i] + c) if i + 3 <= p: NDP[i + 3] = min(NDP[i + 3], DP[i] + 1) DP = NDP print(DP[p] / n)