結果

問題 No.398 ハーフパイプ(2)
ユーザー h_nosonh_noson
提出日時 2016-07-29 23:16:14
言語 C++11
(gcc 11.4.0)
結果
CE  
(最新)
AC  
(最初)
実行時間 -
コード長 1,684 bytes
コンパイル時間 567 ms
コンパイル使用メモリ 73,520 KB
最終ジャッジ日時 2024-11-14 19:48:06
合計ジャッジ時間 1,040 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。

コンパイルメッセージ
main.cpp:25:23: error: ‘acos’ was not declared in this scope
   25 | constexpr double PI = acos(-1);
      |                       ^~~~

ソースコード

diff #

#include <iostream>
#include <vector>
#include <map>
#include <set>
#include <queue>
#include <algorithm>
#include <iomanip>
#include <cassert>
using namespace std;

#define GET_ARG(a,b,c,F,...) F
#define REP3(i,s,e) for (i = s; i <= e; i++)
#define REP2(i,n) REP3 (i,0,(int)(n)-1)
#define REP(...) GET_ARG (__VA_ARGS__,REP3,REP2) (__VA_ARGS__)
#define RREP3(i,s,e) for (i = s; i >= e; i--)
#define RREP2(i,n) RREP3 (i,(int)(n)-1,0)
#define RREP(...) GET_ARG (__VA_ARGS__,RREP3,RREP2) (__VA_ARGS__)
#define DEBUG(x) cerr << #x ": " << x << endl

typedef long long ll;

constexpr int INF = 1e8;
constexpr int MOD = 1e9+7;
constexpr int ESP = 1e-9;
constexpr double PI = acos(-1);

int comb[7][7];

int C(int n, int k) {
    if (comb[n][k] > 0) return comb[n][k];
    else if (n == k || k == 0) return comb[n][k] = 1;
    else return comb[n][k] = C(n-1,k) + C(n-1,k-1);
}

int f(vector<int>& v) {
    int i, n = 6;
    int ret = 1;
    REP (i,v.size()) {
        ret *= C(n,v[i]);
        n -= v[i];
    }
    return ret;
}

int main(void) {
    double x;
    cin >> x;
    x *= 4;

    int i, j, k;
    ll ans = 0;
    REP (i,0,100) REP (j,i,100) REP (k,j,100) {
        int rest = x - (i+j+k);
        if (rest < k || rest > 100) continue;
        map<int,int> mp;
        mp[i]++; mp[j]++; mp[k]++; mp[rest]++;
        vector<int> vec;
        for (auto p: mp) vec.push_back(p.second);
        ans += i * (100-rest) * 2 * f(vec);
        vec[0]++;
        ans += (100-rest) * f(vec);
        vec[0]--;
        vec.back()++;
        ans += i * f(vec);
        vec.back()--;
        vec[0]++;
        vec.back()++;
        ans += f(vec);
    }
    cout << ans << endl;
    return 0;
}
0