LightOJ-1274 期望DP

题目链接:https://vjudge.net/contest/76505#problem/I
题目大意:
一个答案文件有n行输出,每行是YES或NO,现在给出文件的总字节数s,YES占3字节,NO占2字节。
要求你输出1个文件,且第一行一定是YES,接下来第i行的内容是答案文件第i-1行的内容,问输出正确行数的期望。

思路:因为第一个一定是YES正着不好DP。我们用f[i][j][k]:前i个还有j个YES没有出现,并且i+1的猜的是k的方案数。

#include<bits/stdc++.h>
#define ll long long
using namespace std;

double f[2][5005][2];
int main(){

    int t, cas=0; scanf("%d", &t);
    while(t--){
        int n, s; scanf("%d%d", &n, &s);
        int yes=s-2*n, no=n-yes;
        memset(f, 0 ,sizeof(f));
        for(int i=n-1; i>=0; i--){
            int MAX=min(i, yes), MIN=max(i-no, 0);
            int now=i%2;
            memset(f[now], 0, sizeof(f[now]));
            for(int j=MAX; j>=MIN; j--){//yes可取的范围
                double p1=(yes-j)*1.0/(n-i), p0=(no-(i-j))*1.0/(n-i);//放yes和no的概率
                //cout<<p1<<" "<<p0<<endl;;
                f[now][j][0]=f[now^1][j][0]*p0+(f[now^1][j+1][1]+1)*p1;//因为i+1实际上出现的数据一定是i+1猜的
                f[now][j][1]=(f[now^1][j][0]+1)*p0+f[now^1][j+1][1]*p1;
                //cout<<f[i][j][0]<<" "<<f[i][j][1]<<endl;
            }
        }
        printf ("Case %d: %.7f\n", ++cas, f[0][0][1]);//第一个一定是YES
    }

    return 0 ;
}
全部评论

相关推荐

下北泽:都是校友,还是同届,我就说直白点,不委婉了,我相信你应该也不是个玻璃心,首先你觉得一个双非的绩点写简历上有用吗?班长职务有用吗?ccf有用吗?企业会关心你高数满分与否吗?第二,第一个项目实在太烂,一眼就能看出是外卖,还是毫无包装的外卖,使用JWT来鉴权,把热点数据放进Redis这两个点居然还能写进简历里,说难听点这两个东西都是学个几十分钟,调用个API就能完成的事情,在双非一本的条件下,这种项目你觉得能拿出手吗,第二个项目你写的东西和你的求职方向有任何的匹配吗?第三,计设那一块毫无价值,如果想突出自己会前端,直接写入专业技能不行吗,最后,专业技能里像深入理解JVM底层原理这种你觉得这句话你自己真的能匹配吗?都是校友加上同届,我措辞直接,但希望能点出你的问题,想进大厂还得继续沉淀项目和学习
点赞 评论 收藏
分享
03-21 11:31
已编辑
门头沟学院 后端
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务