結果
問題 | No.425 ジャンケンの必勝法 |
ユーザー |
|
提出日時 | 2016-10-10 21:53:28 |
言語 | Python2 (2.7.18) |
結果 |
AC
|
実行時間 | 442 ms / 2,000 ms |
コード長 | 490 bytes |
コンパイル時間 | 145 ms |
コンパイル使用メモリ | 6,948 KB |
実行使用メモリ | 23,424 KB |
最終ジャッジ日時 | 2024-11-22 01:11:44 |
合計ジャッジ時間 | 3,487 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 5 |
other | AC * 18 |
ソースコード
# -*- coding: utf-8 -*-import sys,copy,math,heapq,itertools as it,fractions,re,bisect,collections as collesp = 5e-13p, q = map(int, raw_input().split())p, q = p/100.0, q/100.0ans = 1.0/3que = coll.deque([[1.0/3, p]])while que:ak, pk = que.popleft()ans += ak*pk*1.0/2ans += ak*(1 - pk)*1.0/3if ak*pk*1.0/2 > esp: que.append([ak*pk*1.0/2, max(0, pk - q)])if ak*(1 - pk)*1.0/3 > esp: que.append([ak*(1 - pk)*1.0/3, min(1, pk + q)])print "%.10f" % ans