WJMZBMR打osu! / Easy

题目背景

原 维护队列 参见 P1903

题目描述

某一天 WJMZBMR 在打 osu,~~但是他太弱了,有些地方完全靠运气:(~~。 我们来简化一下这个游戏的规则 有 $n$ 次点击要做,成功了就是 `o`,失败了就是 `x`,分数是按 combo 计算的,连续 $a$ 个 combo 就有 $a\times a$ 分,combo 就是极大的连续 `o`。 比如`ooxxxxooooxxx`,分数就是 $2 \times 2 + 4 \times 4 = 4 +16=20$。 Sevenkplus 闲的慌就看他打了一盘,有些地方跟运气无关要么是 `o` 要么是 `x`,有些地方 `o` 或者 `x` 各有 $50\%$ 的可能性,用 `?` 号来表示。 比如 `oo?xx` 就是一个可能的输入。 那么 WJMZBMR 这场 osu 的期望得分是多少呢? 比如 `oo?xx` 的话,`?` 是 `o` 的话就是 `oooxx`($9$),是x的话就是 `ooxxx`($4$),期望自然就是 $(4+9)/2 =6.5$ 了。

输入输出格式

输入格式


第一行一个整数 $n$($n\le3\times10^5$),表示点击的个数 接下来一个字符串,每个字符都是 `o`,`x`,`?` 中的一个

输出格式


一行一个浮点数表示答案 四舍五入到小数点后 $4$ 位 如果害怕精度跪建议用 long double 或者 extended。

输入输出样例

输入样例 #1

4
????

输出样例 #1

4.1250