結果
| 問題 |
No.398 ハーフパイプ(2)
|
| コンテスト | |
| ユーザー |
ふーらくたる
|
| 提出日時 | 2016-07-16 15:42:37 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
MLE
(最新)
AC
(最初)
|
| 実行時間 | - |
| コード長 | 1,221 bytes |
| コンパイル時間 | 548 ms |
| コンパイル使用メモリ | 55,488 KB |
| 実行使用メモリ | 331,476 KB |
| 最終ジャッジ日時 | 2024-06-27 14:41:56 |
| 合計ジャッジ時間 | 7,619 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | MLE * 17 |
ソースコード
#include <iostream>
using namespace std;
#define int long long
double X;
int dp[6][110][110][610];
signed main() {
cin >> X;
int sum = X * 4;
for (int point = 0; point <= 100; point++) {
dp[0][point][point][point] = 1;
}
for (int i = 0; i < 5; i++) {
for (int min_p = 0; min_p <= 100; min_p++) {
for (int max_p = 0; max_p <= 100; max_p++) {
if (min_p > max_p) continue;
for (int sum_p = 0; sum_p <= 600; sum_p++) {
if (dp[i][min_p][max_p][sum_p] == 0) continue;
for (int point = 0; point <= 100; point++) {
dp[i + 1][min(min_p, point)][max(max_p, point)][sum_p + point]
+= dp[i][min_p][max_p][sum_p];
}
}
}
}
}
int ans = 0;
for (int min_p = 0; min_p <= 100; min_p++) {
for (int max_p = 0; max_p <= 100; max_p++) {
for (int sum_p = 0; sum_p <= 600; sum_p++) {
if (sum_p - min_p - max_p == sum) {
ans += dp[5][min_p][max_p][sum_p];
}
}
}
}
cout << ans << endl;
return 0;
}
ふーらくたる