結果
問題 | No.472 平均順位 |
ユーザー |
![]() |
提出日時 | 2017-01-27 21:49:22 |
言語 | C++11 (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 247 ms / 2,000 ms |
コード長 | 960 bytes |
コンパイル時間 | 647 ms |
コンパイル使用メモリ | 68,100 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-12-23 15:57:55 |
合計ジャッジ時間 | 2,942 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 16 |
ソースコード
#include <iostream> #include <vector> #include <iomanip> using ll = long long; const int MAX_N = 5010; ll INF = (1LL << 58); ll dp[MAX_N * 3]; std::vector<ll> rank[MAX_N]; int main() { int n, p; std::cin >> n >> p; for (int i = 0; i < n; i++) { ll a, b, c; std::cin >> a >> b >> c; rank[i].push_back(a); rank[i].push_back(b); rank[i].push_back(c); rank[i].push_back(1); } std::fill(dp, dp + MAX_N * 3, INF); dp[0] = 0; for (int i = 0; i < n; i++) { for (int j = (i + 1) * 3; j >= 0; j--) { ll value = INF; for (int k = 0; k <= 3; k++) { if (j - k < 0) break; value = std::min(value, dp[j - k] + rank[i][k]); } dp[j] = value; } } std::cout << std::fixed << std::setprecision(10) << static_cast<double>(dp[p]) / static_cast<double>(n) << std::endl; return 0; }