結果
| 問題 | No.398 ハーフパイプ(2) |
| コンテスト | |
| ユーザー |
ふーらくたる
|
| 提出日時 | 2016-07-16 15:42:37 |
| 言語 | C++11 (gcc 15.2.0 + boost 1.89.0) |
| 結果 |
AC
|
| 実行時間 | 226 ms / 2,000 ms |
| コード長 | 1,221 bytes |
| 記録 | |
| コンパイル時間 | 588 ms |
| コンパイル使用メモリ | 71,916 KB |
| 実行使用メモリ | 117,120 KB |
| 最終ジャッジ日時 | 2026-03-15 14:06:18 |
| 合計ジャッジ時間 | 5,247 ms |
|
ジャッジサーバーID (参考情報) |
judge1_0 / judge3_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 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;
}
ふーらくたる