結果
問題 | No.2222 Respawn |
ユーザー |
![]() |
提出日時 | 2023-02-17 23:20:52 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 88 ms / 2,000 ms |
コード長 | 515 bytes |
コンパイル時間 | 272 ms |
コンパイル使用メモリ | 82,288 KB |
実行使用メモリ | 75,136 KB |
最終ジャッジ日時 | 2024-07-19 14:31:23 |
合計ジャッジ時間 | 3,122 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 30 |
ソースコード
n = int(input()) s = input() + "#" izon = [0] * n teisu = [0] * (n+1) dp = [0] * (n+1) for i in range(n-2,-1,-1): # dp[i] = izon dp[i] + teisu # teisu / (1 - izon) if s[i] == "#": continue if s[i+1] == "#": izon[i] += 1/3 else: teisu[i] += teisu[i+1] / 3 izon[i] += izon[i+1] / 3 if s[i+2] == "#": izon[i] += 1/3 else: teisu[i] += teisu[i+2] / 3 izon[i] += izon[i+2] / 3 teisu[i] += 1.0 dp[i] = teisu[i] / (1 - izon[i] - 1/3) teisu[i] += dp[i] / 3 print(dp[0]) #print(dp) #print(izon)