結果

問題 No.75 回数の期待値の問題
ユーザー kroton
提出日時 2014-11-24 00:38:05
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
AC  
実行時間 3 ms / 5,000 ms
コード長 796 bytes
コンパイル時間 554 ms
コンパイル使用メモリ 60,052 KB
実行使用メモリ 6,820 KB
最終ジャッジ日時 2025-01-02 21:01:18
合計ジャッジ時間 1,312 ms
ジャッジサーバーID
(参考情報)
judge2 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 16
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <cstring>
using namespace std;

double e;

bool done[222];
double dp[222];
double solve(int N){
    if(N == 0)return 0;
    if(done[N])return dp[N];
    
    double res = 0;
    for(int i=1;i<=6;i++){
        if(N - i < 0){
            res += e;
        } else {
            res += solve(N - i);
        }
    }
    
    res /= 6;
    res += 1;
    
    done[N] = true;
    return dp[N] = res;
}

int main(){
    int K;
    cin >> K;
    
    double lo = 0, hi = 1 << 30;
    for(int i=0;i<100;i++){
        e = (lo + hi) / 2;
        memset(done, false, sizeof(done));
    
        if(solve(K) < e){
            hi = e;
        } else {
            lo = e;
        }
    }
    
    printf("%.15f\n", lo);
    return 0;
}
0