結果

問題 No.472 平均順位
ユーザー OUDONOUDON
提出日時 2017-10-01 18:11:29
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 332 ms / 2,000 ms
コード長 1,201 bytes
コンパイル時間 1,602 ms
コンパイル使用メモリ 167,916 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-11-15 21:34:28
合計ジャッジ時間 5,319 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 16
権限があれば一括ダウンロードができます

ソースコード

diff #
プレゼンテーションモードにする

#include <bits/stdc++.h>
using namespace std;
#define DUMP(x) cerr << #x << "=" << x << endl
#define DUMP2(x, y) cerr<<"("<<#x<<", "<<#y<<") = ("<<x<<", "<<y<<")"<< endl
#define BINARY(x) static_cast<bitset<16> >(x)
#define rep(i,n) for(int i=0;i<(int)(n);i++)
#define REP(i,m,n) for (int i=m;i<(int)(n);i++)
#define in_range(x, y, w, h) (0<=(int)(x) && (int)(x)<(int)(w) && 0<=(int)(y) && (int)(y)<(int)(h))
#define ALL(a) (a).begin(),(a).end()
typedef long long ll;
const int INF = 1e9;
const ll INFLL = 1e18;
typedef pair<int, int> PII;
int dx[4]={0, -1, 1, 0}, dy[4]={-1, 0, 0, 1};
const int MAX_M = 15001;
ll dp[2][MAX_M];
int main()
{
ios::sync_with_stdio(false);
int N, P;
cin >> N >> P;
fill(dp[0], dp[0] + 2 * 15001, INFLL);
dp[0][0] = 0;
rep(i, N) {
int A[4];
rep(j, 3) cin >> A[j];
A[3] = 1;
fill(dp[(i+1)&1], dp[(i+1)&1] + 15001, INFLL);
rep(j, MAX_M) {
rep(k, 4) {
dp[(i+1)&1][j+k] = min(dp[(i+1)&1][j+k], dp[i&1][j] + A[k]);
}
}
#ifdef DEBUG
DUMP(dp[(i+1)&1][0]);
#endif
}
cout << fixed << setprecision(10) << (dp[N&1][P] * 1.0 / N) << endl;
}
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0