一本通OJ-期望分数

期望分数

题意

给定一个字符串由 \(o,x,?\)组成,连续\(o\)贡献\(len^2\)分,对于\(?\)我们已知有\(50\)%概率为\(o\)。求期望值。

分析

显然本题换个角度,因为我们不知道到底可以连续几个\(o\)。所以我们考虑单独\(n\)的贡献。显然可由推导得,若有连续\(len\)个个\(n\)后再来一个\(n\),则有贡献\(2n+1\)。则我们考虑\(n\)的可能性,亦有为\(?\)时长度\(50\)%为1,\(50\)%为0。

代码

#include<bits/stdc++.h>
using namespace std;
char s[5000005];
int n;
double ans,len;
int main(){
    scanf("%d%s",&n,s+1);
    for(int i=1;i<=n;i++){
        if(s[i]=='o'){
            ans+=len*2+1;
            len++;
        }
        else if(s[i]=='x') len=0;
        else{
            ans+=(len*2+1)/2.0;
            len=(len+1)/2.0;
        }
    }
    printf("%.4lf",ans);
    return 0;
}
posted @ 2023-07-25 14:00  Zimo_666  阅读(22)  评论(0编辑  收藏  举报