题意
给定一个由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;
}

本文介绍了一个基于概率的序列得分计算问题。给定一个由xx、oo、??组成的序列,通过递推公式计算出序列中连续oo部分的期望得分。文章提供了完整的C++代码实现。
1万+

被折叠的 条评论
为什么被折叠?



