結果
| 問題 |
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)