結果

問題 No.301 サイコロで確率問題 (1)
ユーザー titiatitia
提出日時 2022-11-03 00:54:07
言語 Python3
(3.12.2 + numpy 1.26.4 + scipy 1.12.0)
結果
TLE  
実行時間 -
コード長 737 bytes
コンパイル時間 181 ms
コンパイル使用メモリ 11,084 KB
実行使用メモリ 8,544 KB
最終ジャッジ日時 2023-09-24 11:35:52
合計ジャッジ時間 3,333 ms
ジャッジサーバーID
(参考情報)
judge15 / judge11
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 TLE -
testcase_01 AC 38 ms
7,792 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

import sys
input = sys.stdin.readline

def solve(x):
    OK=0
    NG=1<<60

    while NG>OK+10**(-6):
        mid=(OK+NG)/2

        DP=[0]*x

        for i in range(x-1,-1,-1):
            score=6
            
            for j in range(1,7):
                if i+j==x:
                    score+=0
                elif i+j>x:
                    score+=mid
                else:
                    score+=DP[i+j]

            if i!=0:
                DP[i]=score/6
            else:
                if score/6>mid:
                    OK=mid
                else:
                    NG=mid

    return OK

t=int(input())
for tests in range(t):
    N=int(input())

    if N<=200:
        print(solve(N))
    else:
        print(N+5/3)
0