题意
给定一个由
x
,
另
因为 (x+1)2−x2=2x+1
那么:
-如果
Si
为
o
,对答案贡献为
-如果
Si
为
x
,对答案贡献为0,
-如果
Si
为
?
,对答案贡献就是
递推一下就好了
#include <cstdio>
#define N 300010
int n;
double f[N],Ans=0;
char A[N];
int main(){
scanf("%d%s",&n,A+1);
for(int i=1;i<=n;i++){
if(A[i]=='o') Ans+=2*f[i-1]+1,f[i]=f[i-1]+1; else
if(A[i]=='x') f[i]=0; else
Ans+=f[i-1]+1.0/2,f[i]=f[i-1]*0.5+0.5;
}
return printf("%.4lf",Ans),0;
}