A101166.Let's Play Osu!

提高+/省选-

通过率:0%

时间限制:1.00s

内存限制:128MB

题目描述

你在玩一个叫做 Osu 的游戏(某音游)!我们来简化一下游戏规则。一局游戏中需要点击 nn 次。每一次点击有两种结果:正确或失误。我们定义正确为符号 O,失误为 X,那么整局游戏可以被写成一个长度为 nn 的由字符 XO 组成的字符串。

用这个字符串你可以用以下的方法计算游戏的得分:对于一个极大的连续的 O 连击,将连击的次数的平方加入到总得分中(即连续的 O 的个数的平方)。举例说明,如果你的游戏序列为 OOXOOOXXOO,那么极大连续的 O 连击共有三个:OOOOOOO,所以你的总得分为 22+32+22=172^2 + 3^2 + 2^2= 17 。如果整局游戏里没有一次成功的点击那么总得分就为 00

你现在知道了第 ii 次 (1in1\leq i\leq n)点击成功的概率为 pip_i,换句话说,字符串中第 ii 个字符有 pip_i 的概率成为 O,有 1pi1-p_i 的概率成为 X,你的任务是算出你游戏总得分的期望值。

输入格式

第一行包含一个整数表示点击的次数 nn (1n105)( 1\leq n\leq 10^5 ) 第二行包含 nn 个由空格间隔开的实数 p1,p2,...,pn(0pi1)p_1,p_2,...,p_n ( 0\leq p_i\leq 1 ) 输入的 pip_i 最多为六位小数。

输出格式

输出一个实数——你游戏的期望得分。你的答案必须与标准答案的误差不超过 10610^{-6}

输入输出样例

  • 输入#1

    3
    0.5 0.5 0.5
    

    输出#1

    2.750000000000000
    
  • 输入#2

    4
    0.7 0.2 0.1 0.9
    

    输出#2

    2.489200000000000
    
  • 输入#3

    5
    1 1 1 1 1
    

    输出#3

    25.000000000000000
    

说明/提示

33 位字符串一共有 88 种不同的情况。每一种出现的概率为 0.1250.125 所以期望得分是 (9+4+2+1+4+1+1)8=2.75\dfrac{(9+4+2+1+4+1+1)}{8}=2.75

首页